請問如何轉換格式(varchar==>日期) |
尚未結案
|
saningamour
一般會員 發表:18 回覆:17 積分:7 註冊:2003-11-17 發送簡訊給我 |
|
sl@cableplus.com.cn
高階會員 發表:168 回覆:359 積分:130 註冊:2004-03-26 發送簡訊給我 |
|
saningamour
一般會員 發表:18 回覆:17 積分:7 註冊:2003-11-17 發送簡訊給我 |
|
change.jian
版主 發表:29 回覆:620 積分:439 註冊:2003-06-02 發送簡訊給我 |
引言: 如 CONVERT(datetime, '2004/7/16 下午 12:54:08', 100) 可是還是會出現該錯誤訊息我想應該是你傳入的格式不正確吧,記得沒錯的話,'2004/7/16 下午 12:54:08'應該不是正確的格式,應該是'Jul 16 2004 12:54',如果參數是帶100的話.雖然我手上沒有convert的參數說明,但我認為應該是傳入的參數錯誤導致,你可以直接把一個DATETIME型態的資料以convert轉成varchar,看看是什麼樣子,以該格式傳入應該就可以了 |
saningamour
一般會員 發表:18 回覆:17 積分:7 註冊:2003-11-17 發送簡訊給我 |
|
timhuang
尊榮會員 發表:78 回覆:1815 積分:1608 註冊:2002-07-15 發送簡訊給我 |
hi, 若資料庫為 MSSQL 的話, 可以利用 case 的方式配合來進行轉換, 但會有效能上的問題, 若資料量不多, 若可以較慢的速度可以接受的話, 可以這麼下:
select convert(datetime, case when charindex('上午', dt) > 0 then replace(dt, '上午', '')+' AM' when charindex('下午', dt) > 0 then replace(dt, '下午', '')+' PM' else null end) as mydatetime, f1, f2, f3 ... from mytable其中 dt 為你資料表中的存時間的 varchar 欄位, mydatetime 為轉型後的 alias name, 若是格式不對會被轉為 null, 這個部分你可以自行調整! |
saningamour
一般會員 發表:18 回覆:17 積分:7 註冊:2003-11-17 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |