问题:
表中某个字段是Datetime型 以" YYYY-MM-DD 00:00:00"格式保存。
例:
A 2009-01-22 21:22:22
B 2009-01-22 19:21:11
C 2009-01-22 23:10:22
使用语句:
select * from TABLE where date between '2009-1-22' And '2009-1-22'
想查找日期为2009-1-22的记录,结果却为零。
解决方法:
--1
select * from tb where convert(varchar(10),riqi,120) = '2009-01-22'
/*
id riqi
---- ------------------------------------------------------
A 2009-01-22 21:22:22.000
B 2009-01-22 19:21:11.000
C 2009-01-22 23:10:22.000
所影响的行数为 3 行)
*/
--2
select * from tb where riqi between '2009-01-22 00:00:00' and '2009-01-22 23:59:59'
/*
id riqi
---- ------------------------------------------------------
A 2009-01-22 21:22:22.000
B 2009-01-22 19:21:11.000
C 2009-01-22 23:10:22.000
(所影响的行数为 3 行)
*/
drop table tb
总结:
短日期类型默认Time为00:00:00,所以当使用between作限制条件时,就相当于between '2009-1-22 00:00:00' and '2009-1-22 00:00:00',因此就查不出数据。
要想实现功能,那就使用连接字串的形式,在短日期后面把时间补全,那样就能实现功能了。
附我的代码: