亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > SQL Server 日期和時間的內部存儲過程

SQL Server 日期和時間的內部存儲過程

熱門標簽:南京電銷外呼系統哪家好 武漢AI電銷機器人 股票配資電銷機器人 在電子版地圖標注要收費嗎 地圖標注如何弄全套標 實體店地圖標注怎么標 萬利達綜合醫院地圖標注點 電銷機器人 深圳 外呼系統會封嗎

在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⁄300秒,精確度為3.33毫秒(0.00333秒,3.33ms),因此,DateTime能夠表示的時間,可能會存在一個滴答的時間誤差。

DateTime的內部存儲格式,用十六進制表示是:DDDDTTTT

  • DDDD:占用2個字節,表示對基準日期的偏移量
  • TTTT:占用兩個字節,表示對午夜之后的始終滴答數

舉個例子,對于如下的日期和時間,把DateTime類型轉換為大小為8個字節的16進制,每兩個數字對應1個字節:

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?

How to Get SQL Server Dates and Times Horribly Wrong

總結

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

您可能感興趣的文章:
  • 解析MySQL中存儲時間日期類型的選擇問題
  • sql server動態存儲過程按日期保存數據示例
  • SQL查詢出表、存儲過程、觸發器的創建時間和最后修改時間示例
  • 返回SQL執行時間的存儲過程

標簽:泰安 汕頭 廣東 臺州 安徽 濟源 武威 濟寧

巨人網絡通訊聲明:本文標題《SQL Server 日期和時間的內部存儲過程》,本文關鍵詞  SQL,Server,日期,和,時,間的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server 日期和時間的內部存儲過程》相關的同類信息!
  • 本頁收集關于SQL Server 日期和時間的內部存儲過程的相關信息資訊供網民參考!
  • 推薦文章
    欧美国产日韩久久久| 九九热国产视频| 欧美激情一区二区三区在线| 欧美激情影院| 高清一级淫片a级中文字幕| 欧美电影免费看大全| 国产成人精品综合久久久| 精品视频免费在线| 日本在线不卡视频| 四虎影视久久久| 国产一区二区精品在线观看| 成人免费一级纶理片| 日本在线www| 欧美大片一区| 国产麻豆精品hdvideoss| 999久久久免费精品国产牛牛| 国产综合91天堂亚洲国产| 999久久66久6只有精品| 精品视频在线观看一区二区| 国产成人精品综合久久久| 国产网站免费观看| 午夜家庭影院| 久草免费资源| 久久国产精品自线拍免费| 精品视频在线看| 成人免费网站久久久| a级毛片免费全部播放| 亚洲女人国产香蕉久久精品| 精品视频一区二区| 精品国产一区二区三区精东影业 | 精品视频一区二区三区免费| 99久久精品国产片| 日日日夜夜操| 国产福利免费视频| 国产不卡高清在线观看视频| 日韩在线观看免费| 国产91精品露脸国语对白| 亚欧视频在线| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 欧美激情一区二区三区在线 | 九九久久99| 黄色免费网站在线| 日本在线不卡视频| 日韩免费在线观看视频| 一级毛片视频在线观看| 国产麻豆精品hdvideoss| 成人免费观看网欧美片| 成人免费观看网欧美片| 欧美a级片视频| 精品视频在线观看视频免费视频| 成人a大片高清在线观看| 欧美激情影院| 欧美另类videosbestsex| 精品视频一区二区三区免费| 日本伦理片网站| 欧美激情在线精品video| 亚洲 激情| 久久成人亚洲| 国产一区二区精品久| 日韩中文字幕在线观看视频| 黄视频网站免费| 国产不卡高清| 亚洲www美色| 欧美国产日韩在线| 欧美大片毛片aaa免费看| 日韩一级精品视频在线观看| 日韩一级黄色| 免费一级片在线观看| 精品国产一区二区三区精东影业 | 国产精品自拍亚洲| 午夜精品国产自在现线拍| 九九久久99| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 亚洲天堂免费观看| 日本在线播放一区| 午夜激情视频在线观看| 尤物视频网站在线观看| 亚欧乱色一区二区三区| 国产极品白嫩美女在线观看看| 免费毛片播放| 久久久久久久网| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产视频一区二区在线播放| 青青久久精品| 国产福利免费视频| 欧美激情影院| 日韩av片免费播放| 国产福利免费视频| 九九久久国产精品| 国产亚洲精品成人a在线| 成人高清护士在线播放| 国产伦精品一区二区三区在线观看| 一级女人毛片人一女人| 国产网站免费| 欧美另类videosbestsex| 一级女性全黄生活片免费| 99热热久久| 成人免费高清视频| 二级特黄绝大片免费视频大片| 精品视频在线观看视频免费视频| 免费的黄色小视频| 成人高清视频在线观看| 国产不卡高清| 免费国产一级特黄aa大片在线| 高清一级片| 精品久久久久久影院免费| 成人av在线播放| 成人免费观看视频| 美女免费精品高清毛片在线视 | 亚洲 激情| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 一级毛片视频在线观看| 四虎精品在线观看| 国产伦精品一区三区视频| 欧美激情一区二区三区视频高清| 国产精品自拍亚洲| 成人免费一级毛片在线播放视频| 青青久久国产成人免费网站| 国产91丝袜在线播放0| 日本特黄特黄aaaaa大片| 日韩专区一区| 国产国产人免费视频成69堂| 成人免费观看视频| 国产伦久视频免费观看 视频| a级毛片免费观看网站| 亚洲 激情| 国产麻豆精品高清在线播放| 日本免费乱理伦片在线观看2018| 色综合久久久久综合体桃花网| 高清一级淫片a级中文字幕| 精品国产一区二区三区精东影业 | 久久国产精品自线拍免费| 国产一区精品| 国产成人精品在线| 你懂的国产精品| 欧美国产日韩在线| 免费国产一级特黄aa大片在线| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 精品在线免费播放| 国产网站在线| 日日夜夜婷婷| 黄视频网站免费看| 久久99中文字幕| 欧美激情一区二区三区在线播放| 国产一级生活片| 精品视频一区二区三区免费| 欧美激情一区二区三区在线 | 日韩男人天堂| 国产高清在线精品一区a| 成人a级高清视频在线观看| 亚洲精品中文一区不卡| 亚洲第一视频在线播放| 日韩专区亚洲综合久久| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日韩专区第一页| 久久久久久久免费视频| 999久久66久6只有精品| 91麻豆tv| 毛片电影网| 一级女性全黄久久生活片| 欧美国产日韩久久久| 欧美激情一区二区三区中文字幕| 久久国产精品只做精品| 国产一区精品| 欧美a级片视频| 韩国三级香港三级日本三级la| 国产伦久视频免费观看 视频| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产不卡在线播放| 久久久久久久免费视频| 国产91精品系列在线观看| 精品在线视频播放| 亚洲天堂免费观看| 精品视频在线观看一区二区| 韩国三级香港三级日本三级| 一本高清在线| 可以在线看黄的网站| 国产激情视频在线观看| 久久精品人人做人人爽97| 国产福利免费视频| 午夜欧美成人久久久久久| 国产网站麻豆精品视频| 国产一区二区精品| 久久成人亚洲| 国产网站麻豆精品视频| 美国一区二区三区| 国产91精品系列在线观看| 成人a大片高清在线观看| 成人免费网站久久久| 日韩在线观看视频黄| 美女免费精品视频在线观看| 国产一区国产二区国产三区| 成人免费观看的视频黄页| 久久成人亚洲| 国产成人精品影视| 成人av在线播放| 沈樵在线观看福利| 黄视频网站免费| 免费国产在线观看不卡| 亚洲第一页色|