DATEDIFF() 函数返回两个日期之间的天数。
语法
DATEDIFF(datepart,startdate,enddate)
startdate 和 enddate 参数是合法的日期表达式。
根据需要知道某个指定日期和公元1年1月1日相差多少天,于是使用datediff来获取:
| 代码如下 | 复制代码 |
|
print datediff(day, '1-1-1', '2014-05-25') |
|
执行结果为4892,这明显是一个错误值,那么1-1-1对应的是哪一天呢?使用dateadd计算下:
| 代码如下 | 复制代码 |
|
|
|
执行结果为2001-01-01,也就是说,公元1年1月1日不能用1-1-1表示,修改脚本:
| 代码如下 | 复制代码 |
|
|
|
错误信息如下:
引用内容
消息 242,级别 16,状态 3,第 1 行
从 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年转换了历法。
附后datdiff函数参数
| datepart | 缩写 |
|---|---|
| 年 | yy, yyyy |
| 季度 | qq, q |
| 月 | mm, m |
| 年中的日 | dy, y |
| 日 | dd, d |
| 周 | wk, ww |
| 星期 | dw, w |
| 小时 | hh |
| 分钟 | mi, n |
| 秒 | ss, s |
| 毫秒 | ms |
| 微妙 | mcs |
| 纳秒 | ns |
《黎明杀机》开发商正开发新的《Serious Sam》游戏 由Devolver发行
超英派遣中心即将登陆Xbox Play Anywhere 深入了解这款独特而备受喜爱的冒险游戏
在《Hunter: The Reckoning – Deathwish》中怎么从猎物蜕变为猎手
《The Expanse: Osiris Reborn》——深入了解玩法 新同伴 封闭测试及发行窗口
Alien Deathstorm 科幻生存与动作结合 打造全新第一人称恐怖混合体验
宝可梦公司已在考虑未来可用口袋妖怪总数达到“或许一万只”
幸存者村庄2
怪可爱的店折相思菜单
怪可爱的店折相思菜单是一款画风治愈的模拟经营佳作,内置折相思菜单解锁多项便利功能
lol电竞经理人手游
lol电竞经理人手游让你可以成为职业的电竞经理人,在游戏中掌控游戏的走向!豪华阵
梦幻奶茶屋小游戏
梦幻奶茶屋是一款主打温馨治愈氛围的休闲经营作品,玩家将化身元气满满的奶茶店店长,
萌宠养成物语无限金币版
萌宠养成物语无限金币版是一款治愈系模拟养成游戏,以可爱卡通画风构建温馨虚拟世界,