关于SQL中Between语句查询日期的问题

系统 3227 0

在CSDN找到了相同的问题描述和解决方法:

问题:

我的表某个字段是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
      
      
        : 
      
      
        create
      
      
      
      
        table
      
      
         tb(id 
      
      
        varchar
      
      
        (
      
      
        1
      
      
        ),riqi 
      
      
        datetime
      
      
        )
        
2 : insert into tb values ( ' A ' , ' 2009-01-22 21:22:22 ' )
3 : insert into tb values ( ' B ' , ' 2009-01-22 19:21:11 ' )
4 : insert into tb values ( ' C ' , ' 2009-01-22 23:10:22 ' )
5 : go
6 : -- 1
7 : select * from tb where convert ( varchar ( 10 ),riqi, 120 ) = ' 2009-01-22 '
8 : /*
9: id riqi
10: ---- ------------------------------------------------------
11: A 2009-01-22 21:22:22.000
12: B 2009-01-22 19:21:11.000
13: C 2009-01-22 23:10:22.000
14:
15: (所影响的行数为 3 行)
16:
*/
17 :
18 : -- 2
19 : select * from tb where riqi between ' 2009-01-22 00:00:00 ' and ' 2009-01-22 23:59:59 '
20 : /*
21: id riqi
22: ---- ------------------------------------------------------
23: A 2009-01-22 21:22:22.000
24: B 2009-01-22 19:21:11.000
25: C 2009-01-22 23:10:22.000
26:
27: (所影响的行数为 3 行)
28:
*/
29 :
30 : drop table tb

总结:

短日期类型默认Time为00:00:00,所以当使用between作限制条件时,就相当于between '2009-1-22 00:00:00'  and '2009-1-22 00:00:00',因此就查不出数据。要想实现功能,那就使用连接字串的形式,在短日期后面把时间补全,那样就能实现功能了。

我的代码:

        
             1:
        
         date1 
        
          between
        
        
          '" + dateTimePicker1.Value.ToShortDateString() + " 00:00:00'
        
        
          and
        
        
          '" + dateTimePicker2.Value.ToShortDateString() + " 23:59:59'
        
      

关于SQL中Between语句查询日期的问题


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论