一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫 - Sql Server - SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ)過程

SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ)過程

2020-06-03 15:03悅光陰 Sql Server

在SQL Server的內(nèi)部存儲(chǔ)中,日期和時(shí)間不是以字符串的形式存儲(chǔ)的,而是使用整數(shù)來存儲(chǔ)的。這篇文章主要介紹了SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ),需要的朋友可以參考下

在SQL Server的內(nèi)部存儲(chǔ)中,日期時(shí)間不是以字符串的形式存儲(chǔ)的,而是使用整數(shù)來存儲(chǔ)的。使用特定的格式來區(qū)分日期部分和時(shí)間部分的偏移量,并通過基準(zhǔn)日期和基準(zhǔn)時(shí)間來還原真實(shí)的數(shù)據(jù)。

一,DateTime的內(nèi)部存儲(chǔ)

SQL Server存儲(chǔ)引擎把DateTime類型存儲(chǔ)為2個(gè)int32類型,共8個(gè)字節(jié),第一個(gè)int32 整數(shù)(前4個(gè)字節(jié))存儲(chǔ)的是日期相對(duì)于基準(zhǔn)日期(1900-01-01)的偏移量。基準(zhǔn)日期是1900-01-01,當(dāng)前4 字節(jié)為0 時(shí),表示的日期是1900 年1 月1 日。第二個(gè)int32整數(shù)(后4個(gè)字節(jié))存儲(chǔ)的是午夜(00:00:00.000)之后的時(shí)鐘滴答數(shù),每個(gè)滴答為1⁄300秒,精確度為3.33毫秒(0.00333秒,3.33ms),因此,DateTime能夠表示的時(shí)間,可能會(huì)存在一個(gè)滴答的時(shí)間誤差。

DateTime的內(nèi)部存儲(chǔ)格式,用十六進(jìn)制表示是:DDDDTTTT

  • DDDD:占用2個(gè)字節(jié),表示對(duì)基準(zhǔn)日期的偏移量
  • TTTT:占用兩個(gè)字節(jié),表示對(duì)午夜之后的始終滴答數(shù)

舉個(gè)例子,對(duì)于如下的日期和時(shí)間,把DateTime類型轉(zhuǎn)換為大小為8個(gè)字節(jié)的16進(jìn)制,每兩個(gè)數(shù)字對(duì)應(yīng)1個(gè)字節(jié):

?
1
2
3
declare @dt datetime = '2015-05-07 10:05:23.187'
select convert(varbinary(8), @dt) as date_time_binary
--output 0x0000A49100A6463C

1,拆分出date和time

把時(shí)間的二進(jìn)制格式中的字節(jié)拆分成兩部分:前4個(gè)字節(jié)表示date,后4個(gè)字節(jié)表示time,得出的結(jié)果如下:

?
1
2
3
4
5
6
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;

SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ)過程

2,通過偏移量還原日期和時(shí)間

通過基準(zhǔn)時(shí)間和偏移量,把整數(shù)還原為原始的日期和時(shí)間:

?
1
2
3
4
5
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

SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ)過程

二,DateTime2的內(nèi)部存儲(chǔ)

DateTime2(n)數(shù)據(jù)類型存儲(chǔ)日期和時(shí)間,它是DateTime的升級(jí)版本,由于小數(shù)秒n的精度可以自主設(shè)置,其存儲(chǔ)大小(Storage Size)不固定,DateTime2(n)占用的存儲(chǔ)空間和小數(shù)秒的精度之間的關(guān)系是:

  • DateTime2(n)內(nèi)部存儲(chǔ)的第一個(gè)字節(jié)存儲(chǔ)精度n,后續(xù)的字節(jié)用于存儲(chǔ)日期和時(shí)間的值。
  • 當(dāng)小數(shù)秒的精度 n < 3 時(shí),總的存儲(chǔ)空間是1B(精度)+6 B(數(shù)據(jù));
  • 當(dāng)小數(shù)秒的精度 n 是 3 - 4 時(shí),總的存儲(chǔ)空間是1B(精度)+ 7B(數(shù)據(jù));
  • 當(dāng)小數(shù)秒的精度 n 是 5 - 7 時(shí),總的存儲(chǔ)空間是1B(精度)+ 8B(數(shù)據(jù)),最大的小數(shù)秒精度是7,默認(rèn)值是7;

1,二進(jìn)制逆序

在探索DateTime2(n)的內(nèi)部存儲(chǔ)之前,先了解一下字節(jié)存儲(chǔ)的“小端”格式和“大端”格式:

  • 大端格式:是指數(shù)據(jù)的低位保存在內(nèi)存的高地址中,而數(shù)據(jù)的高位,保存在內(nèi)存的低地址中;
  • 小端格式:是指數(shù)據(jù)的低位保存在內(nèi)存的低地址中,而數(shù)據(jù)的高位保存在內(nèi)存的高地址中。

舉個(gè)例子,假如內(nèi)存地址左邊是地位,右邊是高位,對(duì)于數(shù)字275,使用兩個(gè)字節(jié)來存儲(chǔ):

  • 如果采用大端格式:字節(jié)序列是0x0113
  • 如果采用小端格式:字節(jié)序列是0x1301

DateTime2(n)的內(nèi)部存儲(chǔ)格式使用的是小端格式,這種格式適合CPU的運(yùn)算。

2,DateTime2的存儲(chǔ)格式

DateTime2(n)的內(nèi)部存儲(chǔ)格式是:

  • 第一字節(jié)存儲(chǔ)的精度n,
  • 后三個(gè)字節(jié)記錄從基準(zhǔn)日期0001-01-01之后的多少天,采用小端格式。
  • 中間余下的字節(jié)記錄子夜之后經(jīng)過的時(shí)間單位間隔(time unit interval,TUI)的數(shù)量,采用小端格式。

TUI是由精度來控制的,每一個(gè)TUI是10的n次方之一秒,也就是:

  • 對(duì)于 DateTime2(7),TUI是100ns;
  • 對(duì)于 DateTime2(6),TUI是1微秒(=1000ns);
  • 對(duì)于 DateTime2(5),TUI是10微秒;
  • 對(duì)于 DateTime2(4),TUI是100微秒;
  • 對(duì)于 DateTime2(3),TUI是1ms(1毫秒=1000微秒);
  •  

為了便于運(yùn)算,把DateTime2(n) 的字節(jié)流逆序排列:前3個(gè)字節(jié)表示的是天數(shù),最后一個(gè)字節(jié)表示的是精度,中間余下的字節(jié)表示的TUI的數(shù)量。例如,對(duì)于 DateTime2(7)按照字節(jié)流逆序處理之后,存儲(chǔ)空間是9個(gè)字節(jié):前三個(gè)字節(jié)是存儲(chǔ)的從基準(zhǔn)日期0001-01-01之后的多少天,最后一位是精度n,中間的5個(gè)字節(jié)表示從子夜開始有多少個(gè)TUI。

2,把DateTime2轉(zhuǎn)換為二進(jìn)制存儲(chǔ)

把DateTime2轉(zhuǎn)換為二進(jìn)制存儲(chǔ),并作逆序處理,DateTime2(3)的精度為3,存儲(chǔ)空間是8個(gè)字節(jié),后三個(gè)字節(jié)記錄從基準(zhǔn)日期0001-01-01之后的多少天,前3個(gè)字節(jié)表示從子夜開始有多少個(gè)TUI。

?
1
2
3
4
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

SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ)過程

把二進(jìn)制值拆分成DateTime2(3)的各個(gè)組成成分:

?
1
2
3
4
5
6
7
8
9
10
11
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;

SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ)過程

3,利用偏移量和基準(zhǔn)還原原始值

有了偏移量,就可以在基準(zhǔn)日期和時(shí)間之上加上偏移量來獲得原始值:

 

?
1
2
3
4
5
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

SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ)過程

參考文檔:

What is the SQL Server 2008 DateTime2 Internal Structure?

How to Get SQL Server Dates and Times Horribly Wrong

總結(jié)

以上所述是小編給大家介紹的SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ),希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)服務(wù)器之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

原文鏈接:https://www.cnblogs.com/ljhdo/p/10208322.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产成人精品视频频 | 日本老妇乱子伦中文视频 | 国产裸露片段精华合集链接 | 色呦呦在线免费观看 | 4438全国最大免费观看 | 欧美精品国产一区二区三区 | 99ri在线精品视频在线播放 | 久久精品一区 | 日韩在线观看网址 | 四虎国产精品免费久久久 | 欧美精品亚洲精品日韩1818 | 美女自插| 超时空要爱国语完整版在线 | 日韩手机在线观看 | 私人黄色影院 | 男女刺激高清视频在线观看 | 99r8这里精品热视频免费看 | 嗯啊在线观看免费影院 | 三级理论在线观看 | 亚洲美女人黄网成人女 | 超碰av| 精品国产欧美一区二区 | 九9热这里只有真品 | 午夜亚洲WWW湿好爽 午夜想想爱午夜剧场 | 超大阿力gaysex| 久久九九有精品国产23百花影院 | 超h 超重口 高h 污肉1v1 | 动漫美丽妇人1~2在线看 | 女女宿舍互慰h文小说 | 白丝女仆被啪到深夜漫画 | 国产精品一区牛牛影视 | 久久精品男人影院 | 亚洲精品卡1卡二卡3卡四卡 | 精品性久久 | 国产一区二区三区久久精品 | 爱情岛永久成人免费网站 | 四虎影院在线免费观看视频 | 久久免费资源福利资源站 | 福利视频一区二区牛牛 | 全黄h全肉细节修仙玄幻文 全彩调教侵犯h本子全彩妖气he | 视频一区在线免费观看 |