My Code:
CONVERT(date,MyDateTime)
--------------------------------------------------------------------------------------------------------------------------
一般存入資料庫中的時間格式為yyyy-mm-ddhh:mm:ss 如果要轉換為yyyy-mm-dd 短日期格式.可以使用convert函數.
下面是sqlserver協助中關於convert函數的聲明:
使用 CONVERT:
CONVERT (data_type[(length)],expression[,style])
參數
expression
是任何有效 Microsoft SQL Server 運算式。 一般就是欄位名。
data_type
目標系統所提供的資料類型,包括bigint和sql_variant。不能使用使用者定義的資料類型。
length
nchar、nvarchar、char、varchar、binary或varbinary資料類型的選擇性參數。
style
日期格式樣式,藉以將datetime或smalldatetime資料轉換為字元資料(nchar、nvarchar、char、varchar、nchar或nvarchar資料類型);或者字串格式樣式,藉以將float、real、money或smallmoney資料轉換為字元資料(nchar、nvarchar、char、varchar、nchar或nvarchar資料類型)。
SQL Server 支援使用科威特演算法的阿拉伯樣式中的資料格式。
在表中,左側的兩列表示將datetime或smalldatetime轉換為字元資料的style值。給style值加 100,可獲得包括世紀數位的四位年份 (yyyy)。
不帶世紀數位 (yy) |
帶世紀數位 (yyyy) |
標準 |
輸入/輸出** |
- |
0 或 100 (*) |
預設值 |
mon dd yyyy hh:miAM(或 PM) |
1 |
101 |
美國 |
mm/dd/yyyy |
2 |
102 |
ANSI |
yy.mm.dd |
3 |
103 |
英國/法國 |
dd/mm/yy |
4 |
104 |
德國 |
dd.mm.yy |
5 |
105 |
意大利 |
dd-mm-yy |
6 |
106 |
- |
dd mon yy |
7 |
107 |
- |
mon dd, yy |
8 |
108 |
- |
hh:mm:ss |
- |
9 或 109 (*) |
預設值 + 毫秒 |
mon dd yyyy hh:mi:ss:mmmAM(或 PM) |
10 |
110 |
美國 |
mm-dd-yy |
11 |
111 |
日本 |
yy/mm/dd |
12 |
112 |
ISO |
yymmdd |
- |
13 或 113 (*) |
歐洲預設值 + 毫秒 |
dd mon yyyy hh:mm:ss:mmm(24h) |
14 |
114 |
- |
hh:mi:ss:mmm(24h) |
- |
20 或 120 (*) |
ODBC 規範 |
yyyy-mm-dd hh:mm:ss[.fff] |
- |
21 或 121 (*) |
ODBC 規範(帶毫秒) |
yyyy-mm-dd hh:mm:ss[.fff] |
- |
126(***) |
ISO8601 |
yyyy-mm-dd Thh:mm:ss:mmm(不含空格) |
- |
130* |
科威特 |
dd mon yyyy hh:mi:ss:mmmAM |
- |
131* |
科威特 |
dd/mm/yy hh:mi:ss:mmmAM |
* 預設值(style0 或 100、9 或 109、13 或 113、20 或 120、21 或 121)始終返回世紀數位 (yyyy)。
** 當轉換為datetime時輸入;當轉換為字元資料時輸出。
*** 專門用於 XML。對於從datetime或smalldatetime到character資料的轉換,輸出格式如表中所示。對於從float、money或smallmoney到character資料的轉換,輸出等同於style2。對於從real到character資料的轉換,輸出等同於style1。
重要 預設情況下,SQL Server 根據截止年份 2049 解釋兩位元字的年份。即,兩位元字的年份 49 被解釋為 2049,而兩位元字的年份 50 被解釋為 1950。許多用戶端應用程式(例如那些基於 OLE Automation 物件的用戶端應用程式)都使用 2030 作為截止年份。SQL Server 提供一個配置選項("兩位元字的截止年份"),藉以更改 SQL Server 所使用的截止年份並對日期進行一致性處理。然而最安全的辦法是指定四位元字年份。
當從smalldatetime轉換為字元資料時,包含秒或毫秒的樣式將在這些位置上顯示零。當從datetime或smalldatetime值進行轉換時,可以通過使用適當的char或varchar資料類型長度來截斷不需要的日期部分。
=========================================================================
如果只要取yyyy-mm-dd格式時間, 就可以用 convert(nvarchar(10),field,120)
120 是格式代碼, nvarchar(10) 是指取出前10位字元.
樣本:
SELECT CONVERT(nvarchar(10), publish_time, 120) FROM table_name
轉自:http://asdic.iteye.com/blog/354118