欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識(shí)庫 > SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ)過程

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

熱門標(biāo)簽:南京電銷外呼系統(tǒng)哪家好 武漢AI電銷機(jī)器人 股票配資電銷機(jī)器人 在電子版地圖標(biāo)注要收費(fèi)嗎 地圖標(biāo)注如何弄全套標(biāo) 實(shí)體店地圖標(biāo)注怎么標(biāo) 萬利達(dá)綜合醫(yī)院地圖標(biāo)注點(diǎn) 電銷機(jī)器人 深圳 外呼系統(tǒng)會(huì)封嗎

在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é):

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é)果如下:

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,通過偏移量還原日期和時(shí)間

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

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的內(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。

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

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

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,利用偏移量和基準(zhǔn)還原原始值

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

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?

How to Get SQL Server Dates and Times Horribly Wrong

總結(jié)

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

您可能感興趣的文章:
  • 解析MySQL中存儲(chǔ)時(shí)間日期類型的選擇問題
  • sql server動(dòng)態(tài)存儲(chǔ)過程按日期保存數(shù)據(jù)示例
  • SQL查詢出表、存儲(chǔ)過程、觸發(fā)器的創(chuàng)建時(shí)間和最后修改時(shí)間示例
  • 返回SQL執(zhí)行時(shí)間的存儲(chǔ)過程

標(biāo)簽:泰安 汕頭 廣東 臺(tái)州 安徽 濟(jì)源 武威 濟(jì)寧

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ)過程》,本文關(guān)鍵詞  SQL,Server,日期,和,時(shí),間的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ)過程》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL Server 日期和時(shí)間的內(nèi)部存儲(chǔ)過程的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    亚洲成a人片在线不卡一二三区 | 亚洲精品视频一区二区| 国产精品一级二级三级| 欧美特级黄色录像| 欧美成人a在线| 蜜桃视频第一区免费观看| 欧美做受喷浆在线观看| 欧美一级专区免费大片| 天堂va蜜桃一区二区三区漫画版 | 日本r级电影在线观看| 国产suv一区二区三区| 中文字幕一区二区在线观看| 成人毛片老司机大片| 91porn在线视频| 亚洲三级视频在线观看| 99精品国产视频| 欧美性感一区二区三区| 亚洲一区二区三区国产| 妖精视频一区二区| 日韩一区二区电影在线| 老司机精品视频一区二区三区| 老牛影视av老牛影视av| 久久亚洲无码视频| 久久综合五月天婷婷伊人| 国产一区二区三区在线观看免费视频| 国产第一页精品| 国产精品久久久久影院老司| 99精品视频在线免费观看| 精品视频在线免费| 日韩国产欧美三级| 少妇av片在线观看| 国产精品国产成人国产三级 | 亚洲主播在线播放| 88av在线播放| 欧美精品一区二区三区蜜桃 | av不卡中文字幕| 欧美一二三区在线| 免费日韩伦理电影| 欧美日韩国产一二三区| 亚洲色欲色欲www| 国产一卡二卡三卡四卡| 26uuu国产在线精品一区二区| 国产激情一区二区三区桃花岛亚洲| 538任你躁在线精品视频网站| 亚洲一区二三区| 成都免费高清电影| 国产精品福利一区二区三区| 丰满人妻一区二区三区大胸| 日韩精品一区二区三区三区免费| 国产福利91精品一区二区三区| 在线视频你懂得一区二区三区| 亚洲成人精品一区二区| 亚洲一二三精品| 亚洲精品大片www| 亚洲第一香蕉网| 亚洲色图视频网| 免费a在线观看播放| 亚洲国产精品精华液2区45| 国产调教打屁股xxxx网站| 欧美精品一区二区三| 成人免费高清在线观看| 91精品国产一区二区人妖| 国产精品一区二区无线| 欧美日韩高清一区二区不卡| 国产乱对白刺激视频不卡| 欧美视频你懂的| 国产美女精品在线| 欧美精品18+| 成人性视频免费网站| 91精品欧美福利在线观看| 粉嫩嫩av羞羞动漫久久久| 制服丝袜亚洲网站| 成人伦理片在线| 精品国产网站在线观看| 丰满人妻一区二区三区53视频| 久久影音资源网| 成年人小视频在线观看| 国产精品免费网站在线观看| 噜噜噜在线视频| 亚洲欧美另类久久久精品2019| 91网站免费视频| 亚洲成av人片在www色猫咪| 中文字幕五月天| 捆绑变态av一区二区三区| 欧美三级在线视频| 成人免费视频免费观看| 亚洲精品一区二区三区香蕉| 亚洲国产精品第一页| 中文字幕一区二区三区蜜月| 成人乱码一区二区三区av| 亚洲综合999| 色八戒一区二区三区| 国产一区二区三区美女| 日韩欧美激情一区| 日本美女视频网站| 亚洲激情中文1区| 老司机成人免费视频| 九九精品一区二区| 日韩一区二区精品| 无码成人精品区在线观看| 亚洲激情网站免费观看| 黑鬼狂亚洲人videos| 国产一区二区三区精品视频| 日韩美女主播在线视频一区二区三区 | 欧美日韩在线不卡| 国产宾馆实践打屁股91| 久久久一区二区三区| 丝袜美腿中文字幕| 日韩中文字幕麻豆| 4438亚洲最大| av av在线| 亚洲一区二区欧美日韩| 在线免费观看日韩欧美| 99热国产精品| 亚洲人成网站精品片在线观看| 亚洲一二三精品| 精品一区二区三区在线播放视频| 日韩精品一区二区三区在线| 在线观看国产免费视频| 图片区小说区国产精品视频| 欧美日韩国产一二三| 成人在线观看一区二区| 亚洲午夜三级在线| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 99久久婷婷国产综合精品电影| 中文字幕色av一区二区三区| 久久精品视频免费在线观看| 成人av电影在线播放| 亚洲图片另类小说| 在线影院国内精品| 无码国产精品久久一区免费| 亚洲午夜羞羞片| 91麻豆精品国产91久久久资源速度 | 亚洲欧洲日韩女同| 国产午夜精品理论片| 成人小视频免费观看| 亚洲视频 欧洲视频| 欧亚一区二区三区| jjzz黄色片| 日韩av成人高清| 日韩三级精品电影久久久| 在线免费观看成年人视频| 另类中文字幕网| 国产午夜精品福利| 欧洲第一无人区观看| 91日韩一区二区三区| 亚洲二区视频在线| 欧美成人午夜电影| 免费一级suv好看的国产网站| 国产91高潮流白浆在线麻豆 | 欧美美女黄视频| 国产呦小j女精品视频| 精品系列免费在线观看| 亚洲国产精品精华液ab| 91成人在线免费观看| www.啪啪.com| 狠狠色狠狠色综合系列| 国产精品久久久久久久久动漫| 欧美影院一区二区| 亚洲一区二区三区综合| 国产一区久久久| 中文字幕一区二区三区视频 | 五月天欧美精品| 精品国产乱码久久久久久蜜臀 | 99在线精品一区二区三区| 亚洲高清不卡在线观看| 2022国产精品视频| 色综合久久久久网| 你懂得在线视频| 国产传媒欧美日韩成人| 亚洲综合成人在线视频| 久久综合一区二区| 欧美主播一区二区三区美女| 中国黄色a级片| 国产成人免费在线观看| 亚洲国产精品久久人人爱| 久久天堂av综合合色蜜桃网| 色94色欧美sute亚洲13| 不卡一区二区在线观看| thepron国产精品| 麻豆国产欧美日韩综合精品二区| 中文字幕人成不卡一区| 日韩欧美亚洲一区二区| 国产suv一区二区三区| 日本黄色网址大全| 成人av集中营| 精品中文av资源站在线观看| 亚洲欧美日韩国产综合| 精品国产成人在线影院| 欧美在线观看18| 嘿嘿视频在线观看| 国产无套精品一区二区三区| 国产在线播精品第三| 亚洲成人黄色影院| 中文字幕av在线一区二区三区| 4438x亚洲最大成人网| 国产女片a归国片aa| www.狠狠爱| 欧美做受高潮中文字幕| 成人黄色a**站在线观看|