ITPub博客

首页 > Linux操作系统 > Linux操作系统 > DBA手记 - optimizer_mode影响一个SQL语句是否可以执行

DBA手记 - optimizer_mode影响一个SQL语句是否可以执行

原创 Linux操作系统 作者:zecaro 时间:2011-04-03 21:31:20 0 删除 编辑
今天现场人员报告说:同样的数据,同样的SQL,在一个产品数据库中可以执行,但是在测试数据库中总是报错。 检查步骤如下: 1。在两个数据库中分别运行SQL,验证是否如现场人员报告的情况,结果属实。 2。查看SQL语句,了解SQL的含义,此时发现该SQL编写不太理想,改写以后在两个数据库中都运行正常,不过这是其它的问题,此处不表 3。检查在两个库中,该SQL的执行计划是否相同,结果不同。 4。检查两个库的版本是否相同,结果相同。 5。检查两个库中的优化模式是否相同,结果不同,此时用alter session修改运行报错的那个数据库的优化模式,再次查看执行计划,发现已经相同了,再次运行SQL,发现可以正常运行。 6。对于此案例,到上面第5步已经可以结束了,如果第5步中发现优化模式相同,那么这步就继续可以查看两个库中两张表的统计信息是否不同 7。如果第6步中还是相同,那么继续检查其它优化相关的参数,比如optimizer_index_cost_adj等 8。如果还相同,那么去查metalink,google,通常可以发现这是一个oracle的bug,确认自己的情况是否属于这个bug。。。 上面是发现一个问题时候我个人的大致处理方法,也许可以给newbies一些帮助。
链接:http://blog.csdn.net/kamus/archive/2005/02/01/276535.aspx

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/23650854/viewspace-691627/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 一年了
下一篇: Oracle V$SESSION_WAIT
请登录后发表评论 登录
全部评论

注册时间:2010-10-28

  • 博文量
    182
  • 访问量
    348650