在SQL Server的内部存储中,日期和时间不是以字符串的形式存储的,而是使用整数来存储的。使用特定的格式来区分日期部分和时间部分的偏移量,并通过基准日期和基准时间来还原真实的数据。
一,DateTime的内部存储
SQL Server存储引擎把DateTime类型存储为2个int32类型,共8个字节,第一个int32 整数(前4个字节)存储的是日期相对于基准日期(1900-01-01)的偏移量。基准日期是1900-01-01,当前4 字节为0 时,表示的日期是1900 年1 月1 日。第二个int32整数(后4个字节)存储的是午夜(00:00:00.000)之后的时钟滴答数,每个滴答为1"htmlcode">
declare @dt datetime = '2015-05-07 10:05:23.187' select convert(varbinary(8), @dt) as date_time_binary --output 0x0000A49100A6463C
1,拆分出date和time
把时间的二进制格式中的字节拆分成两部分:前4个字节表示date,后4个字节表示time,得出的结果如下:
declare @dt datetime = '2015-05-07 10:05:23.187' select substring(convert(varbinary(8), @dt), 1, 4) as date_binary, cast(substring(convert(varbinary(8), @dt), 1, 4) as int) as date_int, substring(convert(varbinary(8), @dt), 5, 4) as time_binary, cast(substring(convert(varbinary(8), @dt), 5, 4) as int) as time_int;
2,通过偏移量还原日期和时间
通过基准时间和偏移量,把整数还原为原始的日期和时间:
declare @Time time='00:00:00.000' declare @Date date='1900-01-01' select dateadd(day, 42129, @Date) as originl_date , dateadd(ms,10896956*10/3, @Time) as original_time
二,DateTime2的内部存储
DateTime2(n)数据类型存储日期和时间,它是DateTime的升级版本,由于小数秒n的精度可以自主设置,其存储大小(Storage Size)不固定,DateTime2(n)占用的存储空间和小数秒的精度之间的关系是:
- DateTime2(n)内部存储的第一个字节存储精度n,后续的字节用于存储日期和时间的值。
- 当小数秒的精度 n < 3 时,总的存储空间是1B(精度)+6 B(数据);
- 当小数秒的精度 n 是 3 - 4 时,总的存储空间是1B(精度)+ 7B(数据);
- 当小数秒的精度 n 是 5 - 7 时,总的存储空间是1B(精度)+ 8B(数据),最大的小数秒精度是7,默认值是7;
1,二进制逆序
在探索DateTime2(n)的内部存储之前,先了解一下字节存储的“小端”格式和“大端”格式:
- 大端格式:是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中;
- 小端格式:是指数据的低位保存在内存的低地址中,而数据的高位保存在内存的高地址中。
举个例子,假如内存地址左边是地位,右边是高位,对于数字275,使用两个字节来存储:
- 如果采用大端格式:字节序列是0x0113
- 如果采用小端格式:字节序列是0x1301
DateTime2(n)的内部存储格式使用的是小端格式,这种格式适合CPU的运算。
2,DateTime2的存储格式
DateTime2(n)的内部存储格式是:
- 第一字节存储的精度n,
- 后三个字节记录从基准日期0001-01-01之后的多少天,采用小端格式。
- 中间余下的字节记录子夜之后经过的时间单位间隔(time unit interval,TUI)的数量,采用小端格式。
TUI是由精度来控制的,每一个TUI是10的n次方之一秒,也就是:
- 对于 DateTime2(7),TUI是100ns;
- 对于 DateTime2(6),TUI是1微秒(=1000ns);
- 对于 DateTime2(5),TUI是10微秒;
- 对于 DateTime2(4),TUI是100微秒;
- 对于 DateTime2(3),TUI是1ms(1毫秒=1000微秒);
为了便于运算,把DateTime2(n) 的字节流逆序排列:前3个字节表示的是天数,最后一个字节表示的是精度,中间余下的字节表示的TUI的数量。例如,对于 DateTime2(7)按照字节流逆序处理之后,存储空间是9个字节:前三个字节是存储的从基准日期0001-01-01之后的多少天,最后一位是精度n,中间的5个字节表示从子夜开始有多少个TUI。
2,把DateTime2转换为二进制存储
把DateTime2转换为二进制存储,并作逆序处理,DateTime2(3)的精度为3,存储空间是8个字节,后三个字节记录从基准日期0001-01-01之后的多少天,前3个字节表示从子夜开始有多少个TUI。
declare @dt datetime2(3)='2015-05-07 10:05:23.187' declare @dt_bi varbinary(max)=convert(varbinary(max), @dt) select @dt_bi as date_time_binary ,convert(varbinary(max),reverse(@dt_bi)) as reverse_binary
把二进制值拆分成DateTime2(3)的各个组成成分:
declare @dt datetime2(3)='2015-05-07 10:05:23.187' declare @dt_bi varbinary(max)=convert(varbinary(max), @dt) declare @dt_bi_littleEnd varbinary(max) select @dt_bi_littleEnd=convert(varbinary(max),reverse(@dt_bi)) select substring(convert(varbinary(8), @dt_bi_littleEnd), 1, 3) as date_binary, cast(substring(convert(varbinary(8), @dt_bi_littleEnd), 1, 3) as int) as date_int, substring(convert(varbinary(8), @dt_bi_littleEnd), 4, 4) as time_binary, cast(substring(convert(varbinary(8), @dt_bi_littleEnd), 4, 4) as int) as time_int, substring(convert(varbinary(8), @dt_bi_littleEnd), 8, 1) as precision_binary, cast(substring(convert(varbinary(8), @dt_bi_littleEnd), 8, 1) as int) as precision_int;
3,利用偏移量和基准还原原始值
有了偏移量,就可以在基准日期和时间之上加上偏移量来获得原始值:
declare @Time time='00:00:00.000' declare @Date date='0001-01-01' select dateadd(day, 735724, @Date) as originl_date , dateadd(ms,36323187, @Time) as original_time
参考文档:
What is the SQL Server 2008 DateTime2 Internal Structure"_blank" href="https://www.red-gate.com/simple-talk/sql/t-sql-programming/how-to-get-sql-server-dates-and-times-horribly-wrong/">How to Get SQL Server Dates and Times Horribly Wrong
总结
以上所述是小编给大家介绍的SQL Server 日期和时间的内部存储,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 宝丽金50周年《国语篇》3CD限定盘 [正版原抓WAV+CUE][2.1G]
- 群星1995-红梅赞·中国歌剧金曲[中唱][WAV+CUE]
- 魏金栋2006-金歌新曲-梦里全是桂花香2CD[天凡之音][WAV+CUE]
- SusieArioli,JordanOfficer-AlltheWay[SP1018](2014)[FLAC]
- 李健《无时无刻》[WAV+CUE][590M]
- 谭咏麟专辑《雾之恋》MQS[FLAC][1.4G]
- 李荣浩《有理想》[FLAC][610M]
- 【小提琴】诹访内晶子AkikoSuwanai-FranckR.StraussViolinSonatas,etc-(24-96,Universal-J
- 徐小鳳-全新歌集2【SACD-ISO】
- [In-Akustik7507]ReferenceSoundEdition-GreatMenOfSong(2015)HQCD[WAV+CUE]
- 【雨果唱片】群星-中国人的歌3CD[日本天龙版][WAV+CUE]
- 群星1990-中国民歌大全2半个月亮爬上来[香港首版][WAV+CUE]
- 群星1990-精装绕樑金曲集3CD[澳洲版][WAV+CUE]
- 张信哲《挚爱》首版金碟[低速原抓WAV分轨][437M]
- 张琼《情思(黑胶CD)》[WAV+CUE][675M]