oracle中的parse,oracle数据库性能影响之Sqlparse-Oracle

1,Sql parse的种类

Sql parse又通常分为硬解析和软解析,当sql第一次执行的时候,会发生硬解析,之后的执行如果在shared pool中能找到就是软解析。因此,为提高数据性能,尽可能的让每次执行的SQL在shared pool找到。

2,SQL在哪些情况下会发送硬解析?

1)统计信息改变

2)Sql中的表上有做ddl操作,包括grant和revoke。

3)执行计划被踢出shared pool

4)开启了trace

5)绑定变量长度变化

6)启用outline,11g启用SPM

7)SQL语句相同但是所引用的表不同,例如不是同一属主

8)环境发生变化,如Sort area size、Hash area size和locale setting发生变化

3,软解析的条件

当你向ORACLE 提交一个SQL语句,ORACLE会首先在共享内存中查找是否有相同的语句。这里需要注明的是,ORACLE对两者采取的是一种严格匹配,要达成共享,SQL语句必须完全相同(包括空格,换行等)。如果完全相同,才会有软解析。

4,如何判断两个sql语句是否是同一个sql语句呢?

1)大小写和空格以及字母值不一致:

SELECT * FROM emp WHERE empno = 1000;

和下列每一个都不同

SELECT * from emp WHERE empno = 1000;

SELECT * FROM emp WHERE empno = 1000;

SELECT * FROM emp WHERE empno = 2000;

在上面的语句中列值都是直接SQL语句中的,我们将这类sql称为硬编码SQL或字面值SQL

2)绑定变量名称不同

使用绑定变量的SQL语句中必须使用相同的名字的绑定变量(bind variables)

例如:

a. 该2个sql语句被认为相同

select * from emp where empno = :empno;

select * from emp where empno = :empno;

b. 该2个sql语句被认为不相同

select * from emp where empno = :empno1;

select * from emp where empno = :empno2;

我们将上面的这类语句称为绑定变量SQL。

3)对象名称相同,但是属主不同

将所发出语句中涉及的对象与已存在语句所涉及对象相比较。

例如:

如用户user1与用户user2下都有EMP表,则

用户user1发出的语句:SELECT * FROM EMP; 与

用户user2发出的语句:SELECT * FROM EMP; 被认为是不相同的语句,

因为两个语句中引用的EMP不是指同一个表。

4) 在SQL语句中使用的捆绑变量的捆绑类型必须一致

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值