日期查询yy-MM-dd与yyyy-MM-dd的区别

dpcrman1987 2012-05-25 06:20:31
今日调试个SQL语句的时候发现 qrydate>'12-05-25'与qrydate>Convert(varchar(10),GETDATE(),120)
查询结果居然不一样,我以为数据库会把'12-05-25'默认为'2012-05-25'


请问有先人知道 qrydate>'12-05-25' 查询条件代表啥呢 (qrydate)为datetime类型
...全文
840 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
dpcrman1987 2012-05-30
  • 打赏
  • 举报
回复
不是,我是超级赛亚人
楼上是龟仙人
Lyongt 2012-05-29
  • 打赏
  • 举报
回复
楼主不会是2K后吧,呵呵?
Lyongt 2012-05-29
  • 打赏
  • 举报
回复
又一个千年虫出来了!
孤独加百列 2012-05-29
  • 打赏
  • 举报
回复
看你的SQL的设置的截止日期,截止日期年份为49年,则49-05-01为2049-05-01,50年为1950年,如果你的截止日期大于12的话,这两个时间是一样的。
Mr_Nice 2012-05-29
  • 打赏
  • 举报
回复
[Quote=引用楼主 的回复:]
今日调试个SQL语句的时候发现 qrydate>'12-05-25'与qrydate>Convert(varchar(10),GETDATE(),120)
查询结果居然不一样,我以为数据库会把'12-05-25'默认为'2012-05-25'


请问有先人知道 qrydate>'12-05-25' 查询条件代表啥呢 (qrydate)为datetime类型
[/Quote]

百年以内是一样的。
dpcrman1987 2012-05-29
  • 打赏
  • 举报
回复
谁来帮把手啊 问题其实没得到解决呢
dpcrman1987 2012-05-28
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 的回复:]

你的查詢器語言是 us_english 的吧.

us_english : xx-xx-xx => mm-dd-yy

简体中文: yy-mm-dd

使用語句:
set language {語言}(us_english,简体中文,...)
[/Quote]
这个有用!
soaringsouth 2012-05-26
  • 打赏
  • 举报
回复
看你的sqlserver的日期格式了
尽量避免这种'12-05-25'
  • 打赏
  • 举报
回复

dateadd 在向指定日期加上一段时间的基础上,返回新的 datetime 值
例如:向日期加上2天
select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.000

3. datediff 返回跨两个指定日期的日期和时间边界数。
select datediff(day,'2004-09-01','2004-09-18') --返回:17

4. datepart 返回代表指定日期的指定日期部分的整数。
select DATEPART(month, '2004-10-15') --返回 10

5. datename 返回代表指定日期的指定日期部分的字符串
select datename(weekday, '2004-10-15') --返回:星期五

6. day(), month(),year() --可以与datepart对照一下

select 当前日期=convert(varchar(10),getdate(),120) ,
当前时间=convert(varchar(8),getdate(),114)

select datename(dw,'2004-10-15')

select 本年第多少周=datename(week,'2004-10-15'),
今天是周几=datename(weekday,'2004-10-15')
 二、日期格式转换
select CONVERT(varchar, getdate(), 120 )
2004-09-12 11:06:08
select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ',''),':','')
20040912110608

select CONVERT(varchar(12) , getdate(), 111 )
2004/09/12

select CONVERT(varchar(12) , getdate(), 112 )
20040912

select CONVERT(varchar(12) , getdate(), 102 )
2004.09.12

其它我不常用的日期格式转换方法:

select CONVERT(varchar(12) , getdate(), 101 )
09/12/2004

select CONVERT(varchar(12) , getdate(), 103 )
12/09/2004

select CONVERT(varchar(12) , getdate(), 104 )
12.09.2004

select CONVERT(varchar(12) , getdate(), 105 )
12-09-2004

select CONVERT(varchar(12) , getdate(), 106 )
12 09 2004

select CONVERT(varchar(12) , getdate(), 107 )
09 12, 2004

select CONVERT(varchar(12) , getdate(), 108 )
11:06:08

select CONVERT(varchar(12) , getdate(), 109 )
09 12 2004 1

select CONVERT(varchar(12) , getdate(), 110 )
09-12-2004

select CONVERT(varchar(12) , getdate(), 113 )
12 09 2004 1

select CONVERT(varchar(12) , getdate(), 114 )
11:06:08.177
我腫了 2012-05-25
  • 打赏
  • 举报
回复
你的查詢器語言是 us_english 的吧.

us_english : xx-xx-xx => mm-dd-yy

简体中文: yy-mm-dd

使用語句:
set language {語言}(us_english,简体中文,...)

34,576

社区成员

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

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