sqlserver convert() 对日期统计出错 只能比较下限,不能比上限

walkman_22 2012-06-11 10:49:46

SELECT COUNT(1)
FROM A1
WHERE CONVERT(VARCHAR(8),A1.TEST_DATE, 112) >= CONVERT(VARCHAR(8), '2012-06-01', 112) --大于
AND CONVERT(VARCHAR(8),A1.TEST_DATE, 112) <= CONVERT(VARCHAR(8), '2012-06-11', 112) --小于



只比较大于日期部分没有问题,加上小于日期部分查询就为空。

请指教,在线急等。
...全文
93 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
walkman_22 2012-06-11
  • 打赏
  • 举报
回复
问题解决了。谢谢Lee大神。膜拜一下。
给分。
孤独加百列 2012-06-11
  • 打赏
  • 举报
回复
[Quote=引用楼主 的回复:]
SQL code

SELECT COUNT(1)
FROM A1
WHERE CONVERT(VARCHAR(8),A1.TEST_DATE, 112) >= CONVERT(VARCHAR(8), '2012-06-01', 112) --大于
AND CONVERT(VARCHAR(8),A1.TEST_DATE, 112) <= CONVERT(VARCHAR(8), '2012-06-……
[/Quote]

VARCHAR(8)长度不够,截取出来的结果为'2012-06-'大于小于是相通的,所以没有结果,变成VARCHAR(10)就可以了
  • 打赏
  • 举报
回复

SELECT COUNT(1)
FROM A1
WHERE CONVERT(VARCHAR(10),A1.TEST_DATE, 112)
between CONVERT(VARCHAR(10), '2012-06-01', 112) --大于
AND CONVERT(VARCHAR(10), '2012-06-11', 112) --小于

34,588

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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