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

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

--*/

相关文章推荐

mysql查询条件的执行顺序

有这样的一个问题mysql查询使用mysql中left(right)join筛选条件在on与where查询出的数据是否有差异。    可能只看着两个关键字看不出任何的问题。那我们使用实际...

CodeIgniter需要注意错写查询条件导致数据库索引失效的问题

在db查询使用query($sql, 绑定参数)的时候,如果数据库字段存储的是char或者是varchar,而值刚好是一些数字串, 此是如果 where = 数字串  不加单引号也是可以查询的,而加...
  • treesky
  • treesky
  • 2012年04月12日 15:44
  • 906

从索引技术谈数据库查询索引建立和查询条件书写

索引的优势当然是提高检索速度,但并不是说数据库建立了索引就真的会提高检索速度.为什么呢?我们知道,索引本身是有序的,索引查找的时候一般是多分查找,(当然在内存用数组实现的索引则可以做到随机查找,但数据...
  • hawksoft
  • hawksoft
  • 2012年04月01日 15:04
  • 10244

ASP.NET查询条件保存Session中

  • 2010年05月31日 10:46
  • 67KB
  • 下载

运用工厂模式封装增删改查,select查询条件

config.php文件    数据库参数

Hibernate在查询条件中创建List集合

  • 2008年11月06日 12:09
  • 493KB
  • 下载

HQL与QBC的查询条件.doc

  • 2008年03月10日 10:40
  • 34KB
  • 下载

datatables 带查询条件java服务端分页处理

使用datatables自带后台查询 前台代码:

ibatis_动态查询条件

  • 2012年09月03日 15:52
  • 20KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:索引对查询条件顺序的影响
举报原因:
原因补充:

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