sqlite 預設目前時間

來源:互聯網
上載者:User

    在SQL Server中,建立表格的時候,對於時間列有時候我們可以根據需要指定預設值為目前時間(也就是說記錄產生的時候有預設的時間戳記)。例如:

create table log(content varchar(256),logtime datetime default getdate())

    然而在Sqlite中如何?呢?查文檔得知Sqlite中並沒有getdate()函數,但其系統內建函數有datetime(),因此能不能按照下面的寫法實現預設時間戳記呢:

 create table log(content varchar(256),logtime datetime default datetime('now'))

    答案是否定的,會提示法錯誤。那麼應該如何聲明呢?如下所示:

create table log(content varchar(256),logtime TIMESTAMP default CURRENT_TIMESTAMP)

    這個可以達到效果,但是預設的時間是以格林尼治標準時間為基準的,因此在中國使用的話會正好早8個小時。為瞭解決這個問題,我們可以這樣聲明:

 create table log(content varchar(256),logtime TIMESTAMP default (datetime('now', 'localtime')))

    測試一下,一切正常:)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.