Sqlserver timestamp數(shù)據(jù)類使用介紹
更新時(shí)間:2011年08月28日 22:01:47 作者:
SQL Server timestamp 數(shù)據(jù)類型與時(shí)間和日期無(wú)關(guān)。SQL Server timestamp 是二進(jìn)制數(shù)字,它表明數(shù)據(jù)庫(kù)中數(shù)據(jù)修改發(fā)生的相對(duì)順序。
在SQL Server中聯(lián)機(jī)叢書是這樣說(shuō)的:
SQL Server timestamp 數(shù)據(jù)類型與時(shí)間和日期無(wú)關(guān)。SQL Server timestamp 是二進(jìn)制數(shù)字,它表明數(shù)據(jù)庫(kù)中數(shù)據(jù)修改發(fā)生的相對(duì)順序。實(shí)現(xiàn) timestamp 數(shù)據(jù)類型最初是為了支持 SQL Server 恢復(fù)算法。每次修改頁(yè)時(shí),都會(huì)使用當(dāng)前的 @@DBTS 值對(duì)其做一次標(biāo)記,然后 @@DBTS 加1。這樣做足以幫助恢復(fù)過(guò)程確定頁(yè)修改的相對(duì)次序,但是 timestamp 值與時(shí)間沒(méi)有任何關(guān)系。
我用口水話解釋一下便于理解:
我們知道數(shù)字類型有個(gè)“標(biāo)識(shí)”屬性,設(shè)置好“標(biāo)識(shí)種子”、“標(biāo)識(shí)遞增量”,每增加一條記錄時(shí),這個(gè)字段的值就會(huì)在最近的一個(gè)標(biāo)識(shí)值基礎(chǔ)上自動(dòng)增加,這樣我們可以知道哪些記錄是先添加的,哪些記錄是后添加的,但是我們無(wú)法知道哪些記錄修改過(guò)。timestamp這個(gè)類型的字段呢,每增加一條記錄時(shí),它會(huì)在最近的一個(gè)時(shí)間戳基礎(chǔ)上自動(dòng)增加,當(dāng)修改某條記錄時(shí),它也會(huì)在最近的一個(gè)時(shí)間戳基礎(chǔ)上自動(dòng)增加,所以我們就知道哪些記錄修改過(guò)了。
timestamp 這種數(shù)據(jù)類型表現(xiàn)自動(dòng)生成的二進(jìn)制數(shù),確保這些數(shù)在數(shù)據(jù)庫(kù)中是唯一的。timestamp 一般用作給表行加版本戳的機(jī)制。存儲(chǔ)大小為 8 字節(jié)。
注釋
Transact-SQL timestamp 數(shù)據(jù)類型與在 SQL-92 標(biāo)準(zhǔn)中定義的 timestamp 數(shù)據(jù)類型不同。SQL-92 timestamp 數(shù)據(jù)類型等價(jià)于 Transact-SQL datetime 數(shù)據(jù)類型。
Microsoft® SQL Server™ 將來(lái)的版本可能會(huì)修改 Transact-SQL timestamp 數(shù)據(jù)類型的行為,使它與在標(biāo)準(zhǔn)中定義的行為一致。到那時(shí),當(dāng)前的 timestamp 數(shù)據(jù)類型將用 rowversion 數(shù)據(jù)類型替換。
Microsoft® SQL Server™ 2000 引入了 timestamp 數(shù)據(jù)類型的 rowversion 同義詞。在 DDL 語(yǔ)句中盡可能使用 rowversion 而不使用 timestamp。rowversion 受數(shù)據(jù)類型同義詞行為的制約。有關(guān)更多信息,請(qǐng)參見(jiàn)數(shù)據(jù)類型同義詞。
在 CREATE TABLE 或 ALTER TABLE 語(yǔ)句中,不必為 timestamp 數(shù)據(jù)類型提供列名:
CREATE TABLE ExampleTable (PriKey int PRIMARY KEY, timestamp)如果沒(méi)有提供列名,SQL Server 將生成 timestamp 的列名。rowversion 數(shù)據(jù)類型同義詞不具有這樣的行為。指定 rowversion 時(shí)必須提供列名。
一個(gè)表只能有一個(gè) timestamp 列。每次插入或更新包含 timestamp 列的行時(shí),timestamp 列中的值均會(huì)更新。這一屬性使 timestamp 列不適合作為鍵使用,尤其是不能作為主鍵使用。對(duì)行的任何更新都會(huì)更改 timestamp 值,從而更改鍵值。如果該列屬于主鍵,那么舊的鍵值將無(wú)效,進(jìn)而引用該舊值的外鍵也將不再有效。如果該表在動(dòng)態(tài)游標(biāo)中引用,則所有更新均會(huì)更改游標(biāo)中行的位置。如果該列屬于索引鍵,則對(duì)數(shù)據(jù)行的所有更新還將導(dǎo)致索引更新。
不可為空的 timestamp 列在語(yǔ)義上等價(jià)于 binary(8) 列??蔀榭盏?timestamp 列在語(yǔ)義上等價(jià)于 varbinary(8) 列。
Microsoft SQL Server 用兩個(gè) 4 字節(jié)的整數(shù)內(nèi)部存儲(chǔ) datetime 數(shù)據(jù)類型的值。第一個(gè) 4 字節(jié)存儲(chǔ) base date(即 1900 年 1 月 1 日)之前或之后的天數(shù)?;A(chǔ)日期是系統(tǒng)參考日期。不允許早于 1753 年 1 月 1 日的 datetime 值。另外一個(gè) 4 字節(jié)存儲(chǔ)以午夜后毫秒數(shù)所代表的每天的時(shí)間。
@@DBTS(SELECT @@DBTS)
為當(dāng)前數(shù)據(jù)庫(kù)返回當(dāng)前 timestamp 數(shù)據(jù)類型的值。這一 timestamp 值保證在數(shù)據(jù)庫(kù)中是唯一的。
語(yǔ)法
@@DBTS
返回類型
varbinary
注釋
@@DBTS
返回當(dāng)前數(shù)據(jù)庫(kù)最后所使用的時(shí)間戳值。當(dāng)帶有 timestamp 列的一行被插入或更新時(shí),會(huì)產(chǎn)生一個(gè)新的時(shí)間戳值。
SQL Server timestamp 數(shù)據(jù)類型與時(shí)間和日期無(wú)關(guān)。SQL Server timestamp 是二進(jìn)制數(shù)字,它表明數(shù)據(jù)庫(kù)中數(shù)據(jù)修改發(fā)生的相對(duì)順序。實(shí)現(xiàn) timestamp 數(shù)據(jù)類型最初是為了支持 SQL Server 恢復(fù)算法。每次修改頁(yè)時(shí),都會(huì)使用當(dāng)前的 @@DBTS 值對(duì)其做一次標(biāo)記,然后 @@DBTS 加1。這樣做足以幫助恢復(fù)過(guò)程確定頁(yè)修改的相對(duì)次序,但是 timestamp 值與時(shí)間沒(méi)有任何關(guān)系。
我用口水話解釋一下便于理解:
我們知道數(shù)字類型有個(gè)“標(biāo)識(shí)”屬性,設(shè)置好“標(biāo)識(shí)種子”、“標(biāo)識(shí)遞增量”,每增加一條記錄時(shí),這個(gè)字段的值就會(huì)在最近的一個(gè)標(biāo)識(shí)值基礎(chǔ)上自動(dòng)增加,這樣我們可以知道哪些記錄是先添加的,哪些記錄是后添加的,但是我們無(wú)法知道哪些記錄修改過(guò)。timestamp這個(gè)類型的字段呢,每增加一條記錄時(shí),它會(huì)在最近的一個(gè)時(shí)間戳基礎(chǔ)上自動(dòng)增加,當(dāng)修改某條記錄時(shí),它也會(huì)在最近的一個(gè)時(shí)間戳基礎(chǔ)上自動(dòng)增加,所以我們就知道哪些記錄修改過(guò)了。
timestamp 這種數(shù)據(jù)類型表現(xiàn)自動(dòng)生成的二進(jìn)制數(shù),確保這些數(shù)在數(shù)據(jù)庫(kù)中是唯一的。timestamp 一般用作給表行加版本戳的機(jī)制。存儲(chǔ)大小為 8 字節(jié)。
注釋
Transact-SQL timestamp 數(shù)據(jù)類型與在 SQL-92 標(biāo)準(zhǔn)中定義的 timestamp 數(shù)據(jù)類型不同。SQL-92 timestamp 數(shù)據(jù)類型等價(jià)于 Transact-SQL datetime 數(shù)據(jù)類型。
Microsoft® SQL Server™ 將來(lái)的版本可能會(huì)修改 Transact-SQL timestamp 數(shù)據(jù)類型的行為,使它與在標(biāo)準(zhǔn)中定義的行為一致。到那時(shí),當(dāng)前的 timestamp 數(shù)據(jù)類型將用 rowversion 數(shù)據(jù)類型替換。
Microsoft® SQL Server™ 2000 引入了 timestamp 數(shù)據(jù)類型的 rowversion 同義詞。在 DDL 語(yǔ)句中盡可能使用 rowversion 而不使用 timestamp。rowversion 受數(shù)據(jù)類型同義詞行為的制約。有關(guān)更多信息,請(qǐng)參見(jiàn)數(shù)據(jù)類型同義詞。
在 CREATE TABLE 或 ALTER TABLE 語(yǔ)句中,不必為 timestamp 數(shù)據(jù)類型提供列名:
CREATE TABLE ExampleTable (PriKey int PRIMARY KEY, timestamp)如果沒(méi)有提供列名,SQL Server 將生成 timestamp 的列名。rowversion 數(shù)據(jù)類型同義詞不具有這樣的行為。指定 rowversion 時(shí)必須提供列名。
一個(gè)表只能有一個(gè) timestamp 列。每次插入或更新包含 timestamp 列的行時(shí),timestamp 列中的值均會(huì)更新。這一屬性使 timestamp 列不適合作為鍵使用,尤其是不能作為主鍵使用。對(duì)行的任何更新都會(huì)更改 timestamp 值,從而更改鍵值。如果該列屬于主鍵,那么舊的鍵值將無(wú)效,進(jìn)而引用該舊值的外鍵也將不再有效。如果該表在動(dòng)態(tài)游標(biāo)中引用,則所有更新均會(huì)更改游標(biāo)中行的位置。如果該列屬于索引鍵,則對(duì)數(shù)據(jù)行的所有更新還將導(dǎo)致索引更新。
不可為空的 timestamp 列在語(yǔ)義上等價(jià)于 binary(8) 列??蔀榭盏?timestamp 列在語(yǔ)義上等價(jià)于 varbinary(8) 列。
Microsoft SQL Server 用兩個(gè) 4 字節(jié)的整數(shù)內(nèi)部存儲(chǔ) datetime 數(shù)據(jù)類型的值。第一個(gè) 4 字節(jié)存儲(chǔ) base date(即 1900 年 1 月 1 日)之前或之后的天數(shù)?;A(chǔ)日期是系統(tǒng)參考日期。不允許早于 1753 年 1 月 1 日的 datetime 值。另外一個(gè) 4 字節(jié)存儲(chǔ)以午夜后毫秒數(shù)所代表的每天的時(shí)間。
復(fù)制代碼 代碼如下:
@@DBTS(SELECT @@DBTS)
為當(dāng)前數(shù)據(jù)庫(kù)返回當(dāng)前 timestamp 數(shù)據(jù)類型的值。這一 timestamp 值保證在數(shù)據(jù)庫(kù)中是唯一的。
語(yǔ)法
@@DBTS
返回類型
varbinary
注釋
@@DBTS
返回當(dāng)前數(shù)據(jù)庫(kù)最后所使用的時(shí)間戳值。當(dāng)帶有 timestamp 列的一行被插入或更新時(shí),會(huì)產(chǎn)生一個(gè)新的時(shí)間戳值。
相關(guān)文章
SQL Server 海量數(shù)據(jù)導(dǎo)入的最快方法
這篇論壇文章(賽迪網(wǎng)技術(shù)社區(qū))詳細(xì)講解了SQL Server海量數(shù)據(jù)導(dǎo)入的最快方法,更多內(nèi)容請(qǐng)參考下文2008-12-12SQLServer 2000 數(shù)據(jù)庫(kù)同步詳細(xì)步驟[兩臺(tái)服務(wù)器]
成功實(shí)現(xiàn)SQL Server 2000 數(shù)據(jù)庫(kù)同步[一臺(tái)服務(wù)器,一臺(tái)動(dòng)態(tài)IP的備份機(jī)],詳細(xì)步驟說(shuō)明。2010-07-07SQL Server內(nèi)存遭遇操作系統(tǒng)進(jìn)程壓榨案例分析
最近一臺(tái)DB服務(wù)器偶爾出現(xiàn)CPU報(bào)警,我的郵件報(bào)警閾值設(shè)置的是15%,開(kāi)始時(shí)沒(méi)當(dāng)回事,以為是有什么統(tǒng)計(jì)類的查詢,后來(lái)越來(lái)越頻繁2014-03-03SQL實(shí)現(xiàn)篩選出連續(xù)3天登錄用戶與窗口函數(shù)的示例代碼
本文主要介紹了SQL實(shí)現(xiàn)篩選出連續(xù)3天登錄用戶與窗口函數(shù)的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04Sql?Server?"用戶登錄失敗,錯(cuò)誤編18456"的解決過(guò)程
在我們使用數(shù)據(jù)庫(kù)的時(shí)候,偶爾會(huì)遇到一些登錄上的錯(cuò)誤提示,下面這篇文章主要給大家介紹了關(guān)于Sql?Server?"用戶登錄失敗,錯(cuò)誤編18456"的解決過(guò)程,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09