不错呦!smile@林凯西,确保“准备文件”中的几个文件都有安装,S...您好,看了您这篇帖子觉得很有帮助。但是有个问题想请...我的修改过了怎么还被恶意注册呢 @jjjjiiii 用PJ快9年了,主要是A...PJ3啊,貌似很少有人用PJ了,现在不是WP就是z...@332347365,我当时接入时错误码没有-10...楼主,ChkValue值应为-103是什么意思呢?...大哥 你最近能看到我发的信息,请跟我联系,我有个制...
sql使用datediff函数得到错误结果一例
编辑:dnawo 日期:2014-05-25
根据需要知道某个指定日期和公元1年1月1日相差多少天,于是使用datediff来获取:
执行结果为4892,这明显是一个错误值,那么1-1-1对应的是哪一天呢?使用dateadd计算下:
执行结果为2001-01-01,也就是说,公元1年1月1日不能用1-1-1表示,修改脚本:
错误信息如下:
引用内容
0001-1-1不能转换成datetime?查阅SQL Server文档,datetime类型日期范围为1753 年1月1日到9999年12月31日,datediff的参数自然也受这个限制。
为什么datetime最小的时间为1753 年1月1日呢?百度说明如下:
引用内容
复制内容到剪贴板
程序代码

print datediff(day, '1-1-1', '2014-05-25')
执行结果为4892,这明显是一个错误值,那么1-1-1对应的是哪一天呢?使用dateadd计算下:
复制内容到剪贴板
程序代码

print dateadd(day, -4892, '2014-05-25')
执行结果为2001-01-01,也就是说,公元1年1月1日不能用1-1-1表示,修改脚本:
复制内容到剪贴板
程序代码

print datediff(day, '0001-1-1', '2014-05-25')
错误信息如下:

消息 242,级别 16,状态 3,第 1 行
从 varchar 数据类型到 datetime 数据类型的转换产生一个超出范围的值。
从 varchar 数据类型到 datetime 数据类型的转换产生一个超出范围的值。
0001-1-1不能转换成datetime?查阅SQL Server文档,datetime类型日期范围为1753 年1月1日到9999年12月31日,datediff的参数自然也受这个限制。
为什么datetime最小的时间为1753 年1月1日呢?百度说明如下:

以前在西方存在有两个历法:儒略历和格里历,这两个历法之间相差几天,当使用儒略历转到格里历时,需要跳过10-13天。所以,如果要存储1753之前的日期,就必须要知道使用的是哪种历法,还要处理被跳过的10天到13天。多数西方国家在1753年转换了历法。






评论: 0 | 引用: 0 | 查看次数: 5618
发表评论
请登录后再发表评论!