索引对查询条件顺序的影响

原创 2004年09月22日 13:10:00

原帖地址:
http://community.csdn.net/Expert/FAQ/FAQ_Index.asp?id=207897

环境:Sql Server2000 +sp4

问题:
select datediff(day,'20040910','20040920')  --这句可以执行

--而下面这句不能执行(有时也可以执行)
--sub_para为varchar(8),错误信息是:从字符串转换为 datetime 时发生语法错误。
select * from T_SUB
where item_local_code='03004'
 and  datediff(day,sub_para,getdate())=29
 and (sub_del_flag<>1)

--而且不能执行的时候,这个语句不会返回任何记录集
select * from t_sub
where  item_local_code='03004'
 and isDate(sub_para)=0

-------------------------------------------------------------------------
--原因,表中创建的索引影响了条件的执行顺序
--导致先执行了 datediff(day,sub_para,getdate())

--下面的测试说明了这个问题
--测试表及数据
create table tb(
item_local_code char(5),
sub_del_flag int,
sub_para varchar(10),
constraint PK_t primary key(sub_para,item_local_code)
)
insert tb select '03004',1,'2003-1-1'
union all select '03005',1,'2003a1-1'
go

--查询语句
select * from (
 select * from tb
 where item_local_code='03004'
  and sub_del_flag<>0
  and isdate(sub_para)=1
) A where datediff(day,sub_para,getdate())>29
go

--删除测试
drop table tb

/*--测试结果

item_local_code sub_del_flag sub_para  
--------------- ------------ ----------
03004           1            2003-1-1

服务器: 消息 241,级别 16,状态 1,行 3
从字符串转换为 datetime 时发生语法错误。

--*/

索引字段顺序对效率的影响

个人总结几点: 1、驱动表中的索引要将区间字段(sendtime之类)放到固定值(orgid等)的后面 2、驱动表的连接字段可以放在索引最后,以避免读取rowid 3、连接表的连接字段要放在索引最前面...
  • dingyilong
  • dingyilong
  • 2013年10月25日 11:00
  • 3028

索引对查询条件顺序的影响

原帖地址:http://community.csdn.net/Expert/FAQ/FAQ_Index.asp?id=207897环境:Sql Server2000 +sp4问题:select dat...
  • chenzhiya
  • chenzhiya
  • 2008年01月03日 15:07
  • 101

oracle中Where子句的条件顺序对性能的影响

【具体出处不可考,请作者见谅】 经常有人问到oracle中的Where子句的条件书写顺序是否对SQL性能有影响,我的直觉是没有影响,因为如果这个顺序有影响,Oracle应该早就能够做到自动优化,但一直...
  • BoWa21C
  • BoWa21C
  • 2013年12月25日 23:22
  • 1305

MySQL优化--where条件字段的顺序对效率的影响 (02)

学生表 Student id(编号) name(名字) age(年龄) height(身高) 1 Tommy 26 170 2 Jerry 23 180 3...
  • Lingfeng928
  • Lingfeng928
  • 2016年09月08日 15:53
  • 2257

索引对查询条件的影响

故障表现:表TB中的列COL列是字符型,里面保存有数字和其他数据,在该字段上面建立了索引,当使用下面的语句查询的时候出现了错误:"将 VARCHAR值AA转换为数据类型为int 的列时发生语法错误"....
  • lgjlry
  • lgjlry
  • 2006年02月20日 05:45
  • 772

浅谈索引对数据库性能的影响

大家都知道,对于数据库来说,常见的瓶颈问题多是CPU or IO过高造成的,如果能够有效的解决这两个问题,那么的确是功德可见的,那么业界现在也有很多的方式在达到这样的目的,比如:在DB层的前面加一个中...
  • yzongyu
  • yzongyu
  • 2013年01月06日 13:22
  • 1387

where条件的顺序是否影响mysql的执行效率

where条件的顺序,where条件的复合索引的顺序,会不会影响效率 复合索引 explain SELECT * FROM `demo` where username=’ss’ and age=42 ...
  • a454213722
  • a454213722
  • 2017年02月15日 18:02
  • 836

mysql的存储引擎innodb、myisam对插入影响和索引对插入的影响

前言一直好奇mysql的存储引擎innodb和myisam对插入影响。 这次我就来做个测试,以下测试供大家参考。drop table userinfo; CREATE TABLE userinfo ...
  • zyt807
  • zyt807
  • 2017年03月18日 17:21
  • 410

索引对idus(增删改查)的影响

索引的原理: 索引是一个B+二叉树。从原理上说B+二叉树的特性 决定了对insert、update、delete、select的影响和作用。 索引优点:查询效率变快。 索引缺点:建立索引过多,会影...
  • aeolus_pu
  • aeolus_pu
  • 2017年02月28日 17:03
  • 668

Oracle提高SQL查询效率where语句条件的先后次序

(1)选择最有效率的表名顺序(只在基于规则的优化器中有效):  Oracle的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 driving table)将...
  • Brilliant_06
  • Brilliant_06
  • 2017年11月22日 11:14
  • 370
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:索引对查询条件顺序的影响
举报原因:
原因补充:

(最多只允许输入30个字)