CONVERT函数全部用法对日期操作

 --功能概述:CONVERT函数全部用法

格式:
CONVERT(data_type,expression[,style])

说明:
(datetime,smalldatetime)与字符串类型(nchar,nvarchar,char,varchar)相互转换的时候才用到的函数的3个参数,
第1个参数为,转换后的大小,第2个为转换日期的字段或函数,第3个为转换的格式,具体如下:
0 | 0 or 100 | mon dd yyyy hh:miAM(或PM)
1 | 101 | mm/dd/yy
2 | 102 | 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 | 9 or 109 | mon dd yyyy hh:mi:ss:mmmmAM(或PM)
10 | 110 | mm-dd-yy
11 | 111 | yy/mm/dd
12 | 112 | yymmdd
11| 13 or 113 | dd mon yyyy hh:mi:ss:mmm(24小时制)
14 | 114 | hh:mi:ss:mmm(24小时制)
15 | 20 or 120 | yyyy-mm-dd hh:mi:ss(24小时制)
16 | 21 or 121 | yyyy-mm-dd hh:mi:ss:mmm(24小时制)
具体例子:
SELECT CONVERT(varchar(100), GETDATE(), 0)union--: 05 16 2006 10:57AM
SELECT CONVERT(varchar(100), GETDATE(), 1)union--: 05/16/06
SELECT CONVERT(varchar(100), GETDATE(), 2)union--: 06.05.16
SELECT CONVERT(varchar(100), GETDATE(), 3)union--: 16/05/06
SELECT CONVERT(varchar(100), GETDATE(), 4)union--: 16.05.06
SELECT CONVERT(varchar(100), GETDATE(), 5)union--: 16-05-06
SELECT CONVERT(varchar(100), GETDATE(), 6)union--: 16 05 06
SELECT CONVERT(varchar(100), GETDATE(), 7)union--: 05 16, 06
SELECT CONVERT(varchar(100), GETDATE(), 8)union--: 10:57:46
SELECT CONVERT(varchar(100), GETDATE(), 9)union--: 05 16 2006 10:57:46:827AM
SELECT CONVERT(varchar(100), GETDATE(), 10)union--: 05-16-06
SELECT CONVERT(varchar(100), GETDATE(), 11)union--: 06/05/16
SELECT CONVERT(varchar(100), GETDATE(), 12)union--: 060516
SELECT CONVERT(varchar(100), GETDATE(), 13)union--: 16 05 2006 10:57:46:937
SELECT CONVERT(varchar(100), GETDATE(), 14)union--: 10:57:46:967
SELECT CONVERT(varchar(100), GETDATE(), 20)union--: 2006-05-16 10:57:47
SELECT CONVERT(varchar(100), GETDATE(), 21)union--: 2006-05-16 10:57:47.157
SELECT CONVERT(varchar(100), GETDATE(), 22)union--: 05/16/06 10:57:47 AM
SELECT CONVERT(varchar(100), GETDATE(), 23)union--: 2006-05-16
SELECT CONVERT(varchar(100), GETDATE(), 24)union---: 10:57:47
SELECT CONVERT(varchar(100), GETDATE(), 25)union--: 2006-05-16 10:57:47.250
SELECT CONVERT(varchar(100), GETDATE(), 101)union--: 05/16/2006
SELECT CONVERT(varchar(100), GETDATE(), 102)union--: 2006.05.16
SELECT CONVERT(varchar(100), GETDATE(), 103)union--: 16/05/2006
SELECT CONVERT(varchar(100), GETDATE(), 104)union---: 16.05.2006
SELECT CONVERT(varchar(100), GETDATE(), 105)union--: 16-05-2006
SELECT CONVERT(varchar(100), GETDATE(), 106)union--: 16 05 2006
SELECT CONVERT(varchar(100), GETDATE(), 107)union---: 05 16, 2006
SELECT CONVERT(varchar(100), GETDATE(), 108)union--: 10:57:49
SELECT CONVERT(varchar(100), GETDATE(), 109)union--: 05 16 2006 10:57:49:437AM
SELECT CONVERT(varchar(100), GETDATE(), 110)union--: 05-16-2006
SELECT CONVERT(varchar(100), GETDATE(), 111)union--: 2006/05/16
SELECT CONVERT(varchar(100), GETDATE(), 112)union--: 20060516
SELECT CONVERT(varchar(100), GETDATE(), 113)union--: 16 05 2006 10:57:49:513
SELECT CONVERT(varchar(100), GETDATE(), 114)union--: 10:57:49:547
SELECT CONVERT(varchar(100), GETDATE(), 120)union--: 2006-05-16 10:57:49
SELECT CONVERT(varchar(100), GETDATE(), 121)union--: 2006-05-16 10:57:49.700
SELECT CONVERT(varchar(100), GETDATE(), 126)union--: 2006-05-16T10:57:49.827
SELECT CONVERT(varchar(100), GETDATE(), 130)union--: 18 ???? ?????? 1427 10:57:49:907AM
SELECT CONVERT(varchar(100), GETDATE(), 131)--: 18/04/1427 10:57:49:920AM

<think>嗯,用户想了解SQL中CONVERT函数用于日期转换的使用方法。首先,我需要回顾一下CONVERT函数的基本语法和用途。根据引用[1],CONVERT函数的作用是将日期转换为新数据类型,并且可以指定不同的格式显示日期/时间数据。语法是CONVERT(data_type(length), expression, style),其中style参数决定日期格式。 接下来,用户可能需要具体的示例来说明不同style的用法。引用[3]给出了一些例子,比如样式代码23对应'YYYY-MM-DD',101对应'MM/DD/YYYY',103是'DD/MM/YYYY',112是'YYYYMMDD'。这些例子可以帮助用户理解不同样式代码的效果。 然后,用户可能想知道常用的日期格式代码。比如,style代码20或120对应日期时间格式,而108是时间部分。需要整理这些常用的代码,并举例说明,比如使用不同的style转换当前日期。 此外,用户可能会关心使用时需要注意的事项,比如不同数据库系统的兼容性。比如,CONVERT在SQL Server中支持style参数,但在MySQL或Oracle中可能不同,这时候应该建议使用数据库特定的函数DATE_FORMAT或TO_DATE。 另外,是否需要提到与CAST函数的区别?比如CAST是ANSI标准,而CONVERT提供了更多格式控制,这可能对用户有帮助,帮助他们选择适合的函数。 还要考虑用户可能的实际应用场景,比如数据报表中的日期格式统一,或者数据迁移时的格式转换。需要强调style参数的重要性,以及如何避免因格式错误导致的转换失败,比如无效的日期字符串。 需要检查是否所有信息都准确引用了提供的资料,比如引用[1]、[2]、[3]中的内容是否正确对应到解释部分。例如,引用[2]提到CONVERT是强大的数据类型转换工具,适用于不同场景,所以可以建议用户根据需求灵活选择样式。 最后,生成相关问题时要确保覆盖用户可能进一步询问的方向,比如日期格式化、与其他函数的比较、常见错误处理等。这样能帮助用户更全面地理解和应用CONVERT函数。</think>### SQL CONVERT函数日期转换详解 在SQL Server中,`CONVERT`函数是处理日期格式转换的核心工具,其核心语法为: $$ \text{CONVERT}(data\_type, expression, style) $$ 其中`style`参数决定了日期/时间的显示格式[^1][^3]。以下通过具体场景说明其使用方法: --- #### 一、基础日期转换 **场景**:将字符串转换为标准日期格式 ```sql -- 转换"20231001"为DATE类型(样式代码112表示紧凑格式) SELECT CONVERT(DATE, '20231001', 112) AS CompactDate; ``` 输出结果:`2023-10-01`[^3] --- #### 二、常用日期格式代码 | 样式代码 | 格式示例 | 用例 | |----------|-----------------|-------------------------------| | 23 | `YYYY-MM-DD` | `CONVERT(VARCHAR, GETDATE(), 23)` → `2023-10-01` | | 101 | `MM/DD/YYYY` | `CONVERT(VARCHAR, GETDATE(), 101)` → `10/01/2023` | | 103 | `DD/MM/YYYY` | `CONVERT(VARCHAR, GETDATE(), 103)` → `01/10/2023` | | 120 | `YYYY-MM-DD HH:MI:SS` | `CONVERT(VARCHAR, GETDATE(), 120)` → `2023-10-01 14:30:45`[^1][^3] --- #### 三、日期时间组合转换 **场景**:提取日期时间中的特定部分 ```sql -- 仅保留时间部分(样式代码108) SELECT CONVERT(VARCHAR, GETDATE(), 108) AS TimeOnly; -- 输出:14:30:45 ``` --- #### 四、注意事项 1. **兼容性差异**:`CONVERT`的`style`参数是SQL Server特有语法,其他数据库如MySQL需用`DATE_FORMAT`函数[^2] 2. **格式匹配**:输入字符串必须与样式代码隐含的格式一致,否则会报错 (例如样式112要求输入类似`20231001`的紧凑格式) 3. **数据类型选择**:目标类型需与转换需求匹配,如`DATE`仅保留日期,`DATETIME`包含时间[^1] --- #### 五、与CAST函数对比 | 特性 | CONVERT | CAST | |-------------|-----------------------------|--------------------| | 格式控制 | 支持`style`参数定制格式 | 无格式参数 | | 标准化 | SQL Server扩展功能 | ANSI SQL标准 | | 典型用例 | 需要特定日期格式输出的场景 | 简单类型转换 | ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值