首页 > 代码库 > sql语句查询条件的不同表达方式对查询性能的影响

sql语句查询条件的不同表达方式对查询性能的影响

今天操作数据库遇到一个问题

目标表RA_AD_DAILY_DATA的数据量大概有5千万左右,其中的BUSINESS_DATE字段为日期类型

我要查询8月20号导入的三条记录,刚开始用这种方式去查:

SELECT * FROM RA_AD_DAILY_DATA WHERE  to_char(BUSINESS_DATE,‘yyyy-MM-dd‘)= ‘2014-08-20‘ ;

速度非常慢,五分钟左右才能出来结果(在PL/SQL developer中)

同样都是查询2014年8月20日的数据,换一种表达的方式

SELECT * FROM RA_AD_DAILY_DATA WHERE  BUSINESS_DATE= to_date(‘2014-08-20‘,‘yyyy-MM-dd‘) ;

只用了0.3秒就查询出来了

第一种方式要把所有的数据库里边的BUSINESS_DATE字段都变成字符串类型然后再进行比较,因为数据库的数据量非常大,所以是不可取的