問題:
我們通常會碰到這樣的情況:查詢要求,輸入或者日歷控件產(chǎn)生的日期格式為 yyyy-mm-dd,而數(shù)據(jù)庫中的字段是datetime類型,即yyyy-mm-dd hh:mm:ss。如果簡單的使用between語句或者=語句進行查詢,查詢結(jié)果可能是錯誤或者數(shù)據(jù)不全。
假設(shè) 數(shù)據(jù)庫中有 2008-2-27 日的數(shù)據(jù),但直接使用 fielddate='2008-2-27' 或者使用 between '2008-2-27' and '2008-2-27'將不能查到該天的數(shù)據(jù)。
方案:
使用SQL Server提供的Convert函數(shù)進行轉(zhuǎn)換,由于2008-02-27最長是10位,所以使用如下語句 convert(varchar(10),fielddate,121))進行轉(zhuǎn)換,其中fielddate為數(shù)據(jù)表的字段名。這樣在查詢時數(shù)據(jù)庫得到參數(shù)后先自動將數(shù)據(jù)庫內(nèi)的信息轉(zhuǎn)換為yyyy-mm-dd格式的10位字符,只要與參數(shù)相同即可返回查詢結(jié)果.而convert中的121是指將datetime類型轉(zhuǎn)換為char類型時獲得包括世紀位數(shù)的4位年份。
Convert函數(shù)的一些說明,以下資料來源于網(wǎng)絡(luò)
不帶世紀數(shù)位 (yy)帶世紀數(shù)位 (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 規(guī)范yyyy-mm-dd hh:mm:ss[.fff]-21 或 121 (*) ODBC 規(guī)范(帶毫秒)yyyy-mm-dd hh:mm:ss[.fff]-126(***)ISO8601yyyy-mm-dd Thh:mm:ss:mmm(不含空格)-130*科威特dd mon yyyy hh:mi:ss:mmmAM-131*科威特dd/mm/yy hh:mi:ss:mmmAM
默認值(style 0 或 100、9 或 109、13 或 113、20 或 120、21 或 121)始終返回世紀數(shù)位 (yyyy)。
當轉(zhuǎn)換為 datetime 時輸入;當轉(zhuǎn)換為字符數(shù)據(jù)時輸出。
專門用于 XML。對于從 datetime 或 smalldatetime 到 character 數(shù)據(jù)的轉(zhuǎn)換,輸出格式如表中所示。對于從 float、money 或 smallmoney 到 character 數(shù)據(jù)的轉(zhuǎn)換,輸出等同于 style 2。對于從 real 到 character 數(shù)據(jù)的轉(zhuǎn)換,輸出等同于 style 1。
使用 CONVERT:
