什么是ACS(adaptiver cursor sharing)
Oracle通过绑定变量技术解决了SQL语句硬解析过多的问题,降低了资源的争用。但是绑定变量在引入cursor sharing,增加了软解析的同时,也带来了CBO环境下的bind peeking问题。
注:所谓bind peeking是指,oracle在第一次解析sql的时候,会“偷偷”地(peek)查看一下输入的绑定变量值,然后根据“偷看”到的数据值来确定执行计划,保存在liberary cache中,作为下一次的执行计划。这就带来一个问题,如果下次sql输入的变量恰好是和第一次取值分布差异很大的数据值,那么对该sql来讲就有可能使用低效甚至是错误的执行计划。
从oracle11g开始,为了弥补bind peeking的缺陷,oracle引入了ACS(Adaptive Cursor Sharing)技术,该技术将绑定变量的执行计划变为一个基于统计量分析的自适应过程,会根据绑定变量的数值动态调整执行计划。
Oracle使用ACS有两个前提条件:
- 绑定变量使用了bind peeking。
- 绑定变量的列上有直方图信息
- 相关参数
参考信息:
http://www.itpub.net/thread-1762279-1-1.html
http://www.dataguru.cn/thread-532237-1-1.html
http://blog.itpub.net/15415488/viewspace-621535http://blog.itpub.net/53956/viewspace-1384122/http://blog.csdn.net/leshami/article/details/6923670http://www.itpub.net/thread-1779225-1-1.html