您的位置:首页 > 数据库

SQL 时间格式格式化

2009-02-04 18:26 302 查看
SQL 时间格式格式化
将时间格式显示为:2007年5月18日

-- 2005年5月18日

SELECT CAST(YEAR(GETDATE()) AS NVARCHAR) + '年' + CAST(MONTH(GETDATE()) AS NVARCHAR) +'月' + CAST(DAY(GETDATE()) AS NVARCHAR) + '日'

-- 2005年05月18日

SELECT CAST(YEAR(GETDATE()) AS NVARCHAR) + '年' + (CASE WHEN MONTH(GETDATE())<10 THEN '0' ELSE '' END) + CAST(MONTH(GETDATE()) AS NVARCHAR) +'月' + (CASE WHEN DAY(GETDATE())<10 THEN '0' ELSE '' END) + CAST(DAY(GETDATE()) AS NVARCHAR) + '日'

SQL server 内置支持格式

使用 CONVERT 函数:

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

下表中,左侧的两列表示将 datetimesmalldatetime 转换为字符数据的 style 值。给 style 值加 100,可获得包括世纪数位的四位年份 (yyyy)。

不带世纪数位 (yy)带世纪数位 (yyyy)标准输入/输出**
-0 或 100 (*) 默认值mon dd yyyy hh:miAM(或 PM)
1101美国mm/dd/yyyy
2102ANSIyy.mm.dd
3103英国/法国dd/mm/yy
4104德国dd.mm.yy
5105意大利dd-mm-yy
6106-dd mon yy
7107-mon dd, yy
8108-hh:mm:ss
-9 或 109 (*) 默认值 + 毫秒mon dd yyyy hh:mi:ss:mmmAM(或 PM)
10110美国mm-dd-yy
11111日本yy/mm/dd
12112ISOyymmdd
-13 或 113 (*) 欧洲默认值 + 毫秒dd mon yyyy hh:mm:ss:mmm(24h)
14114-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(***)ISO8601yyyy-mm-dd Thh:mm:ss:mmm(不含空格)
-130*科威特dd mon yyyy hh:mi:ss:mmmAM
-131*科威特dd/mm/yy hh:mi:ss:mmmAM
* 默认值(style 0 或 100、9 或 109、13 或 113、20 或 120、21 或 121)始终返回世纪数位 (yyyy)。

** 当转换为 datetime 时输入;当转换为字符数据时输出。

更多信息参见:SQL 联机丛书

格式化建议:

正常情况下,我们不需要在存储过程中或者内联SQL语句中,格式化化输出时间日期类型,而应该按原样返回给应用程序,将格式化工作留给应用程序,这样灵活性更大,更加方便。

对于C# 中格式化日期请参考:

日期与时间格式字符串

标准 DateTime 格式字符串

自定义 DateTime 格式字符串
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: