1,sql parse的种类
sql parse又通常分为硬解析和软解析,当sql第一次执行的时候,会发生硬解析,之后的执行如果在shared pool中能找到就是软解析。因此,为提高数据性能,尽可能的让每次执行的sql在shared pool找到。
2,sql在哪些情况下会发送硬解析?
)统计信息改变
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 = 2000;
在上面的语句中列值都是直接sql语句中的,我们将这类sql称为硬编码sql或字面值sql
2)绑定变量名称不同
使用绑定变量的sql语句中必须使用相同的名字的绑定变量(bind variables)
例如:
a. 该2个sql语句被认为相同
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语句中使用的捆绑变量的捆绑类型必须一致