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

原创 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 时发生语法错误。

--*/

索引的使用跟查询的and的前后顺序没有关系

索引的使用跟查询的and的前后顺序没有关系依然记得以前看网上的帖子的时候说查询要按照顺序来,不能将and的前后顺序弄反了,不然用不了索引.今天上课听老师讲才发现原来跟and的顺序没关系.使用的引擎是i...
  • w20175357
  • w20175357
  • 2016年07月26日 15:01
  • 1256

索引的使用跟查询的and的前后顺序没有关系

索引的使用跟查询的and的前后顺序没有关系依然记得以前看网上的帖子的时候说查询要按照顺序来,不能将and的前后顺序弄反了,不然用不了索引.今天上课听老师讲才发现原来跟and的顺序没关系.使用的引擎是i...
  • w20175357
  • w20175357
  • 2016年07月26日 15:01
  • 1256

索引对排序的影响

索引不仅能提高查询速度,还可以添加排序速度,如果order by 后面的语句用到了索引,那么将会提高排序的速度。测试1、创建测试表:t15表CREATE TABLE `t15` ( `id` in...
  • baochao95
  • baochao95
  • 2017年03月16日 19:47
  • 1315

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

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

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

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

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

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

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

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

mysql组合索引与字段顺序

转自:sunada 很多时候,我们在mysql中创建了索引,但是某些查询还是很慢,根本就没有使用到索引!一般来说,可能是某些字段没有创建索引,或者是组合索引中字段的顺序与查询语句中字段的顺序...
  • gang_strong
  • gang_strong
  • 2017年01月09日 15:26
  • 2134

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

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

如何应对并发-关于数据索引

从整体架构来说分很多部分,比如常见的,存储层的i/o优化,网络层负载均衡,通讯层的连接池等等,不过我这里不讲这些。不讲这些的原因第一呢,是这些我基本都不太会;第二呢,是在实践过程中发现,特别是创业公司...
  • qq_32120645
  • qq_32120645
  • 2017年06月06日 16:07
  • 267
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:索引对查询条件顺序的影响
举报原因:
原因补充:

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