SQL查询条件时间类型的疑问

Sheng450422 2014-07-31 09:28:08
数据库有个表A,其中有个字段B,类型是smalldatetime,我想查询A表中30号的数据,语句如下
SELECT * FROM A WHERE B>='2014-07-30 00:00:00' AND B<='2014-07-30 23:59:59'

但是查询结果中有31号的数据,为什么呢?例如B字段值为2014-07-31 00:00:00也会被查询出来,但我想要的是30号的数据
只是想问一下原因,另外如果是datetime类型会不会也有这个问题?
...全文
143 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
俺是大菠萝 2014-07-31
  • 打赏
  • 举报
回复
smalldatetime只精确到分钟,你2014-07-30 23:59:59,实际转化成2014-07-31- 00:00:00了,在0~29秒的范围舍弃,30~59秒的范围向上入位
CREATE TABLE #tmp (dt SMALLDATETIME)

INSERT INTO #tmp(dt) VALUES('2014-07-30 23:59:00'),('2014-07-30 23:59:59'),('2014-07-31 00:00:00'),('2014-07-31 00:00:29')
,('2014-07-31 00:00:30')

SELECT * FROM #tmp WHERE dt>='2014-07-30 00:00:00' AND dt<='2014-07-30 23:59:59'
唐诗三百首 2014-07-31
  • 打赏
  • 举报
回复
因为smalldatetime数据类型的秒始终为0, 2014-07-30 23:59:59将舍入为2014-07-31 00:00:00. 所以查询结果中有31号的数据. 参考 http://msdn.microsoft.com/zh-cn/library/ms182418(v=sql.105).aspx 须转为datetime类型后再进行比较,如下代码,

create table A(B smalldatetime)

insert into A(B)
 select '2014-07-31 00:00:00' union all
 select '2014-07-30 00:00:00' union all
 select '2014-07-29 00:00:00'


select * 
 from A 
 where B>=cast('2014-07-30 00:00:00' as datetime) 
 and B<=cast('2014-07-30 23:59:59' as datetime)

/*
B
-----------------------
2014-07-30 00:00:00

(1 row(s) affected)
*/
向东流 2014-07-31
  • 打赏
  • 举报
回复
SQL Server中,smalldatetime只能精确到分钟,而datatime可以精确到3%秒(3.33毫秒) 所以 '2014-07-30 23:59:59',秒会“四舍五入”,就是'2014-07-31 00:00:00'

22,301

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧