一个简单的sql为什么没走索引
1个回答
展开全部
走不走索引是由Oracle自己决定的。
Oracle做决定是基于统计信息的。
用绑定变量,传入变量之前,SQL执行计划就必须已经就绪了,所以可能会出现判断错误的结果。
自己拼接SQL,Oracle解析的时候会判断这个变量,根据统计信息决定走什么样的执行计划。
还有,如果索引维护出现问题,使用索引可能会得出和常规查询不一样的(错误的)结果,这时无论如何都不会走索引。
如果“analyze表之后,带参数的sql也走索引了。但我发现一天以后这个毛病就又返了”
说明你的这个表每天都会发生不规范的变化,破坏了索引。
Oracle做决定是基于统计信息的。
用绑定变量,传入变量之前,SQL执行计划就必须已经就绪了,所以可能会出现判断错误的结果。
自己拼接SQL,Oracle解析的时候会判断这个变量,根据统计信息决定走什么样的执行计划。
还有,如果索引维护出现问题,使用索引可能会得出和常规查询不一样的(错误的)结果,这时无论如何都不会走索引。
如果“analyze表之后,带参数的sql也走索引了。但我发现一天以后这个毛病就又返了”
说明你的这个表每天都会发生不规范的变化,破坏了索引。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询