oracle 表字段类型,与业务SQL不合理,导致的隐式转换

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle 表字段类型,与业务SQL不合理,导致的隐式转换相关的知识,希望对你有一定的参考价值。

今天遇到一个生产问题,业务SQL很简单,单表查询,而且表只有三个字段,有个主键ID,而且通过主键ID过滤,业务页面会传一百多个ID过来调用SQL,这个表数据量大小为100多万,但是偏偏这条SQL执行跑了15秒,完全影响业务不能使用。

select a,b,c from t where t.id in (1111,222,333,444,555..........)

我一开始并没有去查看表设计,而是直接看了执行计划,

1 alter session set statistics_level=all;
2 执行SQL
3 select * from table(dbms_xplan.display_cursor(null,null,‘ALLSTATS LAST‘)

执行计划直接走了全表扫描,而在谓词过滤的信息里有一堆的

to_number(t.id)=1111 or to_number(t.id)=2222 ..............

看到这里立马就猜想到了具体的问题所在,查询T表ID字段,是VARCHAR2类型,而SQL in的是数字类型,SQL直接被隐式转换后,便走不了索引了, 直接走了全表。这个问题后续才发现,也是因为业务不关注,在表数据日益上涨之后,性能问题日益凸显才被抛出来

以上是关于oracle 表字段类型,与业务SQL不合理,导致的隐式转换的主要内容,如果未能解决你的问题,请参考以下文章

Oracle-SQL程序优化3

mysql如何判断某些日期不合法

oracle中怎么用sql查表以及表的字段名

Oracle SQL

SQL 导出表的问题?字段类型为啥会改变~

oracle操作表的sql复习