主頁 > 知識庫 > Sqlserver timestamp數(shù)據(jù)類使用介紹

Sqlserver timestamp數(shù)據(jù)類使用介紹

熱門標(biāo)簽:蘭州語音外呼系統(tǒng)運營商 成都電話外呼系統(tǒng)一般多少錢 銀川高頻外呼回?fù)芟到y(tǒng)多少錢 如何做地圖標(biāo)注圖鋪 陜西電銷外呼系統(tǒng)好用嗎 al智能電話機器人 最新人工智能電銷機器人 沒聽見電話機器人幫你接 數(shù)字匠心電銷機器人
在SQL Server中聯(lián)機叢書是這樣說的:
SQL Server timestamp 數(shù)據(jù)類型與時間和日期無關(guān)。SQL Server timestamp 是二進制數(shù)字,它表明數(shù)據(jù)庫中數(shù)據(jù)修改發(fā)生的相對順序。實現(xiàn) timestamp 數(shù)據(jù)類型最初是為了支持 SQL Server 恢復(fù)算法。每次修改頁時,都會使用當(dāng)前的 @@DBTS 值對其做一次標(biāo)記,然后 @@DBTS 加1。這樣做足以幫助恢復(fù)過程確定頁修改的相對次序,但是 timestamp 值與時間沒有任何關(guān)系。
我用口水話解釋一下便于理解:
我們知道數(shù)字類型有個“標(biāo)識”屬性,設(shè)置好“標(biāo)識種子”、“標(biāo)識遞增量”,每增加一條記錄時,這個字段的值就會在最近的一個標(biāo)識值基礎(chǔ)上自動增加,這樣我們可以知道哪些記錄是先添加的,哪些記錄是后添加的,但是我們無法知道哪些記錄修改過。timestamp這個類型的字段呢,每增加一條記錄時,它會在最近的一個時間戳基礎(chǔ)上自動增加,當(dāng)修改某條記錄時,它也會在最近的一個時間戳基礎(chǔ)上自動增加,所以我們就知道哪些記錄修改過了。

timestamp 這種數(shù)據(jù)類型表現(xiàn)自動生成的二進制數(shù),確保這些數(shù)在數(shù)據(jù)庫中是唯一的。timestamp 一般用作給表行加版本戳的機制。存儲大小為 8 字節(jié)。
注釋
Transact-SQL timestamp 數(shù)據(jù)類型與在 SQL-92 標(biāo)準(zhǔn)中定義的 timestamp 數(shù)據(jù)類型不同。SQL-92 timestamp 數(shù)據(jù)類型等價于 Transact-SQL datetime 數(shù)據(jù)類型。
Microsoft® SQL Server™ 將來的版本可能會修改 Transact-SQL timestamp 數(shù)據(jù)類型的行為,使它與在標(biāo)準(zhǔn)中定義的行為一致。到那時,當(dāng)前的 timestamp 數(shù)據(jù)類型將用 rowversion 數(shù)據(jù)類型替換。
Microsoft® SQL Server™ 2000 引入了 timestamp 數(shù)據(jù)類型的 rowversion 同義詞。在 DDL 語句中盡可能使用 rowversion 而不使用 timestamp。rowversion 受數(shù)據(jù)類型同義詞行為的制約。有關(guān)更多信息,請參見數(shù)據(jù)類型同義詞。
在 CREATE TABLE 或 ALTER TABLE 語句中,不必為 timestamp 數(shù)據(jù)類型提供列名:
CREATE TABLE ExampleTable (PriKey int PRIMARY KEY, timestamp)如果沒有提供列名,SQL Server 將生成 timestamp 的列名。rowversion 數(shù)據(jù)類型同義詞不具有這樣的行為。指定 rowversion 時必須提供列名。
一個表只能有一個 timestamp 列。每次插入或更新包含 timestamp 列的行時,timestamp 列中的值均會更新。這一屬性使 timestamp 列不適合作為鍵使用,尤其是不能作為主鍵使用。對行的任何更新都會更改 timestamp 值,從而更改鍵值。如果該列屬于主鍵,那么舊的鍵值將無效,進而引用該舊值的外鍵也將不再有效。如果該表在動態(tài)游標(biāo)中引用,則所有更新均會更改游標(biāo)中行的位置。如果該列屬于索引鍵,則對數(shù)據(jù)行的所有更新還將導(dǎo)致索引更新。
不可為空的 timestamp 列在語義上等價于 binary(8) 列??蔀榭盏?timestamp 列在語義上等價于 varbinary(8) 列。

Microsoft SQL Server 用兩個 4 字節(jié)的整數(shù)內(nèi)部存儲 datetime 數(shù)據(jù)類型的值。第一個 4 字節(jié)存儲 base date(即 1900 年 1 月 1 日)之前或之后的天數(shù)?;A(chǔ)日期是系統(tǒng)參考日期。不允許早于 1753 年 1 月 1 日的 datetime 值。另外一個 4 字節(jié)存儲以午夜后毫秒數(shù)所代表的每天的時間。

復(fù)制代碼 代碼如下:

@@DBTS(SELECT @@DBTS)
為當(dāng)前數(shù)據(jù)庫返回當(dāng)前 timestamp 數(shù)據(jù)類型的值。這一 timestamp 值保證在數(shù)據(jù)庫中是唯一的。
語法
@@DBTS
返回類型
varbinary
注釋
@@DBTS

返回當(dāng)前數(shù)據(jù)庫最后所使用的時間戳值。當(dāng)帶有 timestamp 列的一行被插入或更新時,會產(chǎn)生一個新的時間戳值。
您可能感興趣的文章:
  • MySQL timestamp的類型與時區(qū)實例詳解
  • mysql之TIMESTAMP(時間戳)用法詳解
  • MySQL錯誤TIMESTAMP column with CURRENT_TIMESTAMP的解決方法
  • MySQL timestamp自動更新時間分享
  • mysql From_unixtime及UNIX_TIMESTAMP及DATE_FORMAT日期函數(shù)
  • SQL計算timestamp的差值的方法

標(biāo)簽:本溪 遼源 邢臺 朔州 通化 巴彥淖爾 鹽城 宜春

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Sqlserver timestamp數(shù)據(jù)類使用介紹》,本文關(guān)鍵詞  Sqlserver,timestamp,數(shù)據(jù),類,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Sqlserver timestamp數(shù)據(jù)類使用介紹》相關(guān)的同類信息!
  • 本頁收集關(guān)于Sqlserver timestamp數(shù)據(jù)類使用介紹的相關(guān)信息資訊供網(wǎng)民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章