好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

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

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

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

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

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

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

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

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

舉個例子,對于如下的日期和時間,把DateTime類型轉(zhuǎn)換為大小為8個字節(jié)的16進制,每兩個數(shù)字對應(yīng)1個字節(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

把時間的二進制格式中的字節(jié)拆分成兩部分:前4個字節(jié)表示date,后4個字節(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ù)還原為原始的日期和時間:

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)部存儲

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

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

1,二進制逆序

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

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

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

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

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

2,DateTime2的存儲格式

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

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

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) 的字節(jié)流逆序排列:前3個字節(jié)表示的是天數(shù),最后一個字節(jié)表示的是精度,中間余下的字節(jié)表示的TUI的數(shù)量。例如,對于 DateTime2(7)按照字節(jié)流逆序處理之后,存儲空間是9個字節(jié):前三個字節(jié)是存儲的從基準日期0001-01-01之后的多少天,最后一位是精度n,中間的5個字節(jié)表示從子夜開始有多少個TUI。

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

把DateTime2轉(zhuǎn)換為二進制存儲,并作逆序處理,DateTime2(3)的精度為3,存儲空間是8個字節(jié),后三個字節(jié)記錄從基準日期0001-01-01之后的多少天,前3個字節(jié)表示從子夜開始有多少個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

總結(jié)

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

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標題《SQL Server 日期和時間的內(nèi)部存儲過程》,本文關(guān)鍵詞  SQL,Server,日期,和,時,間的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL Server 日期和時間的內(nèi)部存儲過程》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL Server 日期和時間的內(nèi)部存儲過程的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 汤唯被内谢流白浆10分钟| 女人精69xxxxx免费无毒| 天堂电影院免费观看| 99精品国产第一福利网站| 色鬼A片免费看| 国产两男一女3p刺激视频| 日本哺乳期xxxxhd奶水| 国产露脸对白刺激2022| 精品国产污污污免费入口15| 一区二区三区精品国产欧美| 强行糟蹋强行蹂躏视频| 乳色吐息未删减老牛影视| 国产精品久久久久久无码人妻| 黄色aa毛片| 成人男女网18免费0| 亚洲欧美曰韩国产综合图片| 微拍 福利视频 国产| 美女露双乳| 打开腿我想亲亲你下面视频| 同桌好大好硬受不了了| 91久久偷偷做嫩草影院免| 男女自偷自拍视频免费观看篇| 精品国产福利久久久| 特别黄的大片免费的黄大师 | 俄罗斯xxxxxbbbbbb极品| 公交车上破了两个嫩苞| 国产精欧美一区二区三区蓝颜男同| 国产精品亚洲第一区在线28石| 日本一卡二卡新区无人区| 成人免费高清| 欧洲色情爽爽久久久网站| 免费在线观看视频a| 夜间十八款禁用软件大全免费下载| 快活影院在线毛片| 午夜伦伦影理论片大片飘花影院| 好大?好紧?好硬?好硬| 天天射久久| 国产精品自拍电影| YJLZZJLZZ亚洲乱熟无码| 亚洲99自由精品偷拍| 久久的精品99精品66|