1. 程式人生 > 其它 >SQL Server 日期格式和日期操作

SQL Server 日期格式和日期操作

一,日期的格式化

格式化是指把日期型別(Date)、日期和時間型別轉化為字元型別,通常使用CONVERT()和FORMAT()函式。

1,傳統的CONVERT()

SQL Server控制日期的的顯示格式,通常使用CONVERT()函式,通過控制style引數來控制日期顯示的格式,但是,style很多,不利於記憶。

CONVERT ( data_type [ ( length ) ] , expression [ , style ] )

符合東方人閱讀習慣的style及其顯示格式如下:

  • 101: mm/dd/yyyy
  • 110: mm-dd-yyyy
  • 111: yyyy/mm/dd
  • 112: yyyymmdd
  • 120: yyyy-mm-dd hh:mm:ss
  • 121: yyyy-mm-dd hh:mm:sssssss

CONVERT()函式的style是數字,記憶起來比較困難,並且只能按照系統定義的格式來顯示,不夠靈活。SQL Server提供更為靈活的轉換函式FORMAT()。

2,便利的FORMAT()函式

FORMAT()函式,可以方便和靈活地控制數值、日期和時間型別的顯示格式,通常情況下,FORMAT()函式主要用於格式化顯示date/time型別和數值型別,引數format用於指定顯示的格式,給予使用者對格式更自由地控制,culture引數是可選的,用於指定顯示的語言,該函式返回值的資料型別是NVARCHAR,如果格式轉換失敗,該函式返回NULL:

FORMAT ( value, format [, culture ] ) 

引數format使用#表示一個數值,引數 format 使用以下佔位符來表示日期/時間的格式:

  • yyyy、MM、dd:表示年、月、日
  • hh:mm:ss fffffff:表示時、分、秒、毫秒
  • 使用“/”,“-”等作為連線各個部分(part)的分割符號

(1)把date/time格式化

在format引數中指定日期/時間顯示的格式,以特定的格式: “yyyy:MMdd hh:mm:ss fffffff” 顯式日期/時間,例如:

select format(SYSDATETIME(),'yyyy-MM-dd hh:mm:ss fffffff')

(2)轉換數值型別

在引數format中使用#代表一個數字,使用相應的連線符,拼接成數字的格式字元,例如:

FORMAT(123456789,'###-##-####') AS 'Custom Number Result

一,日期的格式化

格式化是指把日期型別(Date)、日期和時間型別轉化為字元型別,通常使用CONVERT()和FORMAT()函式。

1,傳統的CONVERT()

SQL Server控制日期的的顯示格式,通常使用CONVERT()函式,通過控制style引數來控制日期顯示的格式,但是,style很多,不利於記憶。

CONVERT ( data_type [ ( length ) ] , expression [ , style ] )

符合東方人閱讀習慣的style及其顯示格式如下:

  • 101: mm/dd/yyyy
  • 110: mm-dd-yyyy
  • 111: yyyy/mm/dd
  • 112: yyyymmdd
  • 120: yyyy-mm-dd hh:mm:ss
  • 121: yyyy-mm-dd hh:mm:sssssss

CONVERT()函式的style是數字,記憶起來比較困難,並且只能按照系統定義的格式來顯示,不夠靈活。SQL Server提供更為靈活的轉換函式FORMAT()。

2,便利的FORMAT()函式

FORMAT()函式,可以方便和靈活地控制數值、日期和時間型別的顯示格式,通常情況下,FORMAT()函式主要用於格式化顯示date/time型別和數值型別,引數format用於指定顯示的格式,給予使用者對格式更自由地控制,culture引數是可選的,用於指定顯示的語言,該函式返回值的資料型別是NVARCHAR,如果格式轉換失敗,該函式返回NULL:

FORMAT ( value, format [, culture ] ) 

引數format使用#表示一個數值,引數 format 使用以下佔位符來表示日期/時間的格式:

  • yyyy、MM、dd:表示年、月、日
  • hh:mm:ss fffffff:表示時、分、秒、毫秒
  • 使用“/”,“-”等作為連線各個部分(part)的分割符號

(1)把date/time格式化

在format引數中指定日期/時間顯示的格式,以特定的格式: “yyyy:MMdd hh:mm:ss fffffff” 顯式日期/時間,例如:

select format(SYSDATETIME(),'yyyy-MM-dd hh:mm:ss fffffff')

(2)轉換數值型別

在引數format中使用#代表一個數字,使用相應的連線符,拼接成數字的格式字元,例如:

FORMAT(123456789,'###-##-####') AS 'Custom Number Result