一个简单的sql为什么没走索引

 我来答
就烦条0o
2017-01-28 · 知道合伙人软件行家
就烦条0o
知道合伙人软件行家
采纳数:33315 获赞数:46492
从事多年系统运维,喜欢编写各种小程序和脚本。

向TA提问 私信TA
展开全部
走不走索引是由Oracle自己决定的。

Oracle做决定是基于统计信息的。

用绑定变量,传入变量之前,SQL执行计划就必须已经就绪了,所以可能会出现判断错误的结果。

自己拼接SQL,Oracle解析的时候会判断这个变量,根据统计信息决定走什么样的执行计划。

还有,如果索引维护出现问题,使用索引可能会得出和常规查询不一样的(错误的)结果,这时无论如何都不会走索引。

如果“analyze表之后,带参数的sql也走索引了。但我发现一天以后这个毛病就又返了”

说明你的这个表每天都会发生不规范的变化,破坏了索引。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式