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