Sqlite實現預設時間為目前時間列的方法

來源:互聯網
上載者:User

標籤:style   blog   http   color   io   os   使用   ar   strong   

原文地址: http://blog.csdn.net/derryzhang/article/details/5033209

 

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

   

[xhtml] view plaincopy
  1. create table log(  
  2.   
  3.    content varchar(256),  
  4.   
  5.    logtime datetime default getdate()  
  6.   
  7.    )  

  

 

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

    

[xhtml] view plaincopy
  1. create table log(  
  2.   
  3.     content varchar(256),  
  4.   
  5.     logtime datetime default datetime(‘now‘)  
  6.   
  7.     )  

  

 

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

   

[c-sharp] view plaincopy
  1. create table log(  
  2.   
  3.    content varchar(256),  
  4.   
  5.    logtime TIMESTAMP default CURRENT_TIMESTAMP  
  6.   
  7.    )  

    

 

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

   

[xhtml] view plaincopy
  1. create table log(  
  2.   
  3.     content varchar(256),  
  4.   
  5.     logtime TIMESTAMP default (datetime(‘now‘, ‘localtime‘))  
  6.   
  7.     )  

 

 

    測試一下,一切正常:)

Sqlite實現預設時間為目前時間列的方法(轉)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.