首页 > 代码库 > 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字段都变成字符串类型然后再进行比较,因为数据库的数据量非常大,所以是不可取的
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。