分享
 
 
 

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

王朝mssql·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

今天现场人员报告说:同样的数据,同样的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一些帮助。

下面是本次案例中的一些SQL操作记录和备注。

interiorid字段是varchar2(100)的类型,存储着一些数字或者字符,下面的SQL在使用to_number函数时报错。

SQL> alter session set optimizer_mode=choose;

Session altered.

SQL> select interiorid, constdisplayname

2 from (select interiorid, constdisplayname

3 from globalconst

4 where globalconst = 'status')

5 where to_number(interiorid) < 4

6 order by to_number(interiorid);

where to_number(interiorid) < 4

*

ERROR at line 5:

ORA-01722: invalid number

此时的执行计划是全表扫描,而且由于报1722错误,所以很明显是因为oracle第一步执行的是全表扫描查询所有to_number(interiorid) < 4的记录,而由于interiorid字段中含有非数字字符,所以报错。

SQL> alter session set optimizer_mode=first_rows;

Session altered.

SQL> select interiorid, constdisplayname

2 from (select interiorid, constdisplayname

3 from globalconst

4 where globalconst = 'status')

5 where to_number(interiorid) < 4

6 order by to_number(interiorid);

INTERIORID CONSTDISPLAYNAME

---------- ----------------------------------------

0 正常

1 销户

2 冻结

3 锁定

Execution Plan

----------------------------------------------------------

0 SELECT STATEMENT Optimizer=FIRST_ROWS (Cost=5 Card=1 Bytes=2

2)

1 0 SORT (ORDER BY) (Cost=5 Card=1 Bytes=22)

2 1 TABLE ACCESS (BY INDEX ROWID) OF 'GLOBALCONST' (Cost=3 C

ard=1 Bytes=22)

3 2 INDEX (RANGE SCAN) OF 'PK_GLOBALCONST' (UNIQUE) (Cost=

2 Card=1)

修改优化模式,SQL开始使用PK进行索引扫描,该索引是globalconst+interiorid构成的联合主键,因为globalconst= 'status'的所有记录interiorid字段都确实是数字,所以这次SQL正常执行了。

SQL> alter session set optimizer_mode=choose;

Session altered.

SQL> select interiorid, constdisplayname

2 from globalconst

3 where globalconst = 'status'

4 and to_number(interiorid) < 4

5 order by 1;

INTERIORID CONSTDISPLAYNAME

---------- ----------------------------------------

0 正常

1 销户

2 冻结

3 锁定

Execution Plan

----------------------------------------------------------

0 SELECT STATEMENT Optimizer=CHOOSE (Cost=3 Card=1 Bytes=22)

1 0 SORT (ORDER BY) (Cost=3 Card=1 Bytes=22)

2 1 TABLE ACCESS (FULL) OF 'GLOBALCONST' (Cost=1 Card=1 Byte

s=22)

我们把SQL换一种写法,虽然执行计划显示的仍然是全表扫描,但是可以推测此时Oracle使用了globalconst = 'status'作为filter的条件,满足条件的再判断是否to_number(interiorid) < 4,而因为globalconst = 'status'的记录interiorid字段都是数字,所以SQL正常执行。

假设我们再insert一条globalconst = 'status'并且interiorid不是数字的记录,再次执行SQL,会发现又报1722错误。

SQL> alter session set optimizer_mode=first_rows;

Session altered.

SQL> select to_number(interiorid), constdisplayname

2 from globalconst

3 where globalconst = 'status'

4 and to_number(interiorid) < 4

5 order by 1;

TO_NUMBER(INTERIORID) CONSTDISPLAYNAME

--------------------- ----------------------------------------

0 正常

1 销户

2 冻结

3 锁定

Execution Plan

----------------------------------------------------------

0 SELECT STATEMENT Optimizer=FIRST_ROWS (Cost=5 Card=1 Bytes=2

2)

1 0 SORT (ORDER BY) (Cost=5 Card=1 Bytes=22)

2 1 TABLE ACCESS (BY INDEX ROWID) OF 'GLOBALCONST' (Cost=3 C

ard=1 Bytes=22)

3 2 INDEX (RANGE SCAN) OF 'PK_GLOBALCONST' (UNIQUE) (Cost=

2 Card=1)

修改优化模式,SQL开始使用PK进行索引扫描,此时SQL跟没有修改前一样,自然也是可以正常执行的

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有