問(wèn)題:
我們通常會(huì)碰到這樣的情況:查詢要求,輸入或者日歷控件產(chǎn)生的日期格式為 yyyy-mm-dd,而數(shù)據(jù)庫(kù)中的字段是datetime類型,即yyyy-mm-dd hh:mm:ss。如果簡(jiǎn)單的使用between語(yǔ)句或者=語(yǔ)句進(jìn)行查詢,查詢結(jié)果可能是錯(cuò)誤或者數(shù)據(jù)不全。
假設(shè) 數(shù)據(jù)庫(kù)中有 2008-2-27 日的數(shù)據(jù),但直接使用 fielddate='2008-2-27' 或者使用 between '2008-2-27' and '2008-2-27'將不能查到該天的數(shù)據(jù)。
方案:
使用SQL Server提供的Convert函數(shù)進(jìn)行轉(zhuǎn)換,由于2008-02-27最長(zhǎng)是10位,所以使用如下語(yǔ)句 convert(varchar(10),fielddate,121))進(jìn)行轉(zhuǎn)換,其中fielddate為數(shù)據(jù)表的字段名。這樣在查詢時(shí)數(shù)據(jù)庫(kù)得到參數(shù)后先自動(dòng)將數(shù)據(jù)庫(kù)內(nèi)的信息轉(zhuǎn)換為yyyy-mm-dd格式的10位字符,只要與參數(shù)相同即可返回查詢結(jié)果.而convert中的121是指將datetime類型轉(zhuǎn)換為char類型時(shí)獲得包括世紀(jì)位數(shù)的4位年份。
Convert函數(shù)的一些說(shuō)明,以下資料來(lái)源于網(wǎng)絡(luò)
不帶世紀(jì)數(shù)位 (yy)帶世紀(jì)數(shù)位 (yyyy)
標(biāo)準(zhǔn):
輸入/輸出**-0 或 100 (*) 默認(rèn)值mon dd yyyy hh:miAM(或 PM)1101美國(guó)mm/dd/yyyy2102ANSIyy.mm.dd3103英國(guó)/法國(guó)dd/mm/yy4104德國(guó)dd.mm.yy5105意大利dd-mm-yy6106-dd mon yy7107-mon dd, yy8108-hh:mm:ss-9 或 109 (*) 默認(rèn)值 + 毫秒mon dd yyyy hh:mi:ss:mmmAM(或 PM)10110美國(guó)mm-dd-yy11111日本yy/mm/dd12112ISOyymmdd-13 或 113 (*) 歐洲默認(rèn)值 + 毫秒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
默認(rèn)值(style 0 或 100、9 或 109、13 或 113、20 或 120、21 或 121)始終返回世紀(jì)數(shù)位 (yyyy)。
當(dāng)轉(zhuǎn)換為 datetime 時(shí)輸入;當(dāng)轉(zhuǎn)換為字符數(shù)據(jù)時(shí)輸出。
專門用于 XML。對(duì)于從 datetime 或 smalldatetime 到 character 數(shù)據(jù)的轉(zhuǎn)換,輸出格式如表中所示。對(duì)于從 float、money 或 smallmoney 到 character 數(shù)據(jù)的轉(zhuǎn)換,輸出等同于 style 2。對(duì)于從 real 到 character 數(shù)據(jù)的轉(zhuǎn)換,輸出等同于 style 1。
使用 CONVERT:

