SQL Server日期查詢時的日期格式轉換
問題提出:
經常會有這樣的查詢要求,輸入或者日歷控件產生的日期格式為 yyyy-mm-dd,而數據庫中的字段是datetime類型,即yyyy-mm-dd hh:mm:ss。如果簡單的使用between語句或者=語句進行查詢,查詢結果可能是錯誤或者數據不全。
假設 數據庫中有 2008-2-27 日的數據,但直接使用 fIElddate='2008-2-27' 或者使用 between '2008-2-27' and '2008-2-27'將不能查到該天的數據。
問題解決:
使用SQL Server提供的Convert函數進行轉換,由於2008-02-27最長是10位,所以使用如下語句 convert(varchar(10),fielddate,121))進行轉換,其中fIElddate為數據表的字段名。這樣在查詢時數據庫得到參數後先自動將數據庫內的信息轉換為yyyy-mm-dd格式的10位字符,只要與參數相同即可返回查詢結果.而convert中的121是指將datetime類型轉換為char類型時獲得包括世紀位數的4位年份。
Convert函數的一些說明,以下資料來源於網絡
不帶世紀數位 (yy)帶世紀數位 (yyyy)
標准
輸入/輸出**-0 或 100 (*) 默認值mon dd yyyy hh:miAM(或 PM)1101美國mm/dd/yyyy2102ANSIyy.mm.dd3103英國/法國dd/mm/yy4104德國dd.mm.yy5105意大利dd-mm-yy6106-dd mon yy7107-mon dd, yy8108-hh:mm:ss-9 或 109 (*) 默認值 + 毫秒mon dd yyyy hh:mi:ss:mmmAM(或 PM)10110美國mm-dd-yy11111日本yy/mm/dd12112ISOyymmdd-13 或 113 (*) 歐洲默認值 + 毫秒dd mon yyyy hh:mm:ss:mmm(24h)14114-hh:mi:ss:mmm(24h)-20 或 120 (*) ODBC 規范
* 默認值(
** 當轉換為
*** 專門用於 XML。對於從
使用 CONVERT:
CONVERT (data_type[(length)], expression [, style])
select CONVERT(varchar, getdate(), 120 )
2004-09-12 11:06:08
select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),\'-\',\'\'),\' \',\'\'),\':\',\'\')
20040912110608
select CONVERT(varchar(12) , getdate(), 111 )
2004/09/12
select CONVERT(varchar(12) , getdate(), 112 )
20040912
select CONVERT(varchar(12) , getdate(), 102 )
2004.09.12
select CONVERT(varchar(12) , getdate(), 101 )
09/12/2004
select CONVERT(varchar(12) , getdate(), 103 )
12/09/2004
select CONVERT(varchar(12) , getdate(), 104 )
12.09.2004
select CONVERT(varchar(12) , getdate(), 105 )
12-09-2004
select CONVERT(varchar(12) , getdate(), 106 )
12 09 2004
select CONVERT(varchar(12) , getdate(), 107 )
09 12, 2004
select CONVERT(varchar(12) , getdate(), 108 )
11:06:08
select CONVERT(varchar(12) , getdate(), 109 )
09 12 2004 1
select CONVERT(varchar(12) , getdate(), 110 )
09-12-2004
select CONVERT(varchar(12) , getdate(), 113 )
12 09 2004 1
select CONVERT(varchar(12) , getdate(), 114 )
11:06:08.177