不一样的 SQL Server 日期格式化

不一样的 sql server 日期格式化

intro

最近统计一些数据,需要按天/按小时/按分钟来统计,涉及到一些日期的格式化,网上看了一些文章大部分都是使用 convert 来转换的,sql server 从 2012 开始增加了 format 方法,可以使用 format 来格式化日期,更标准化,更具可定制性,而且和 c# 里的日期格式化差不多,可以直接把 c# 里日期的格式直接拿过来用

format 介绍

format 适用于数字和日期类型数据的格式化,其他数据类型不支持,其他类型数据转换请使用 convertcast 去转换。

语法

format ( value, format [, culture ] )

  • value

    支持格式化的数据类型的表达式。
    下表列出了 value 参数可接受的数据类型,其中还有相关的 .net framework 映射等效类型。

    类别 | 类型 | .net 类型
    ——————————-
    数字 | bigint | int64
    数字 | int | int32
    数字 | smallint | int16
    数字 | tinyint | byte
    数字 | decimal | decimal
    数字 | numeric | decimal
    数字 | float | double
    数字 | real | single
    数字 | smallmoney | decimal
    数字 | money | decimal
    日期和时间 | date | datetime
    日期和时间 | time | timespan
    日期和时间 | datetime | datetime
    日期和时间 | smalldatetime | datetime
    日期和时间 | datetime2 | datetime
    日期和时间 | datetimeoffset | datetimeoffset

  • format
    nvarchar 格式模式。
    format 参数必须包含一个有效的 .net framework 格式字符串,要么作为标准格式字符串(例如,“c”或“d”),要么作为日期值和数值的自定义字符模式(例如,“mmmm dd, yyyy (dddd)”)。 不支持组合格式。 有关这些格式模式的完整解释,请查阅有关常规字符串格式、自定义日期和时间格式以及自定义数字格式的 .net framework 。

  • culture
    指定区域性的可选 nvarchar 参数。
    如果未提供 culture 参数,则使用当前会话的语言。 可以使用 set language 语句隐式或显式设置此语言。 culture 接受 .net framework 支持的任何区域性作为参数;它不局限于 sql server 显式支持的语言。 如果 culture 参数无效,format 将引发错误。

返回值类型是 nvarchar 或者 null

示例

query | sample output

select format (getdate(), ‘dd/mm/yyyy ‘) | 21/03/2018
select format (getdate(), ‘dd/mm/yyyy, hh:mm:ss ‘) | 21/03/2018, 11:36:14
select format (getdate(), ‘dddd, mmmm, yyyy’) | wednesday, march, 2018
select format (getdate(), ‘mmm dd yyyy’) | mar 21 2018
select format (getdate(), ‘mm.dd.yy’) | 03.21.18
select format (getdate(), ‘mm-dd-yy’) | 03-21-18
select format (getdate(), ‘hh:mm:ss tt’) | 11:36:14 am
select format (getdate(), ‘d’,’us’) | 03/21/2018

和 c# 代码里的格式化格式一致,可以直接使用 c# 里的日期时间格式,数字格式

select format (getdate(), 'yyyymmddhhmmss') >> 20190218033523
select format (getdate(), 'yyyy-mm-dd hh:mm:ss')  >>    2019-02-18 03:35:23
declare @d datetime = getdate();  
select format( @d, 'dd/mm/yyyy', 'en-us' ) as 'datetime result'  
       ,format(123456789,'###-##-####') as 'custom number result';  

output:

datetime result  custom number result  
--------------   --------------------  
27/09/2012       123-45-6789  
  
(1 row(s) affected)  

reference

  • https://docs.microsoft.com/zh-cn/sql/t-sql/functions/format-transact-sql?view=sql-server-2017
(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐