SQL Server中使用convert轉化長日期為短日期

來源:互聯網
上載者:User

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

目標系統所提供的資料類型,包括bigintsql_variant。不能使用使用者定義的資料類型。
length

ncharnvarcharcharvarcharbinaryvarbinary資料類型的選擇性參數。

style

日期格式樣式,藉以將datetimesmalldatetime資料轉換為字元資料(ncharnvarcharcharvarcharncharnvarchar資料類型);或者字串格式樣式,藉以將floatrealmoneysmallmoney資料轉換為字元資料(ncharnvarcharcharvarcharncharnvarchar資料類型)。

SQL Server 支援使用科威特演算法的阿拉伯樣式中的資料格式。

在表中,左側的兩列表示將datetimesmalldatetime轉換為字元資料的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。對於從datetimesmalldatetimecharacter資料的轉換,輸出格式如表中所示。對於從floatmoneysmallmoneycharacter資料的轉換,輸出等同於style2。對於從realcharacter資料的轉換,輸出等同於style1。

重要  預設情況下,SQL Server 根據截止年份 2049 解釋兩位元字的年份。即,兩位元字的年份 49 被解釋為 2049,而兩位元字的年份 50 被解釋為 1950。許多用戶端應用程式(例如那些基於 OLE Automation 物件的用戶端應用程式)都使用 2030 作為截止年份。SQL Server 提供一個配置選項("兩位元字的截止年份"),藉以更改 SQL Server 所使用的截止年份並對日期進行一致性處理。然而最安全的辦法是指定四位元字年份。

當從smalldatetime轉換為字元資料時,包含秒或毫秒的樣式將在這些位置上顯示零。當從datetimesmalldatetime值進行轉換時,可以通過使用適當的charvarchar資料類型長度來截斷不需要的日期部分。
=========================================================================
如果只要取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

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.