sql server中日期类型转字符串几种写法比较

在 SQL Server 中,将 日期类型(如 DATE、DATETIME、DATETIME2)转换为字符串,有多种方法,适用于不同版本和格式需求。以下是常用且高效的写法:

  1. 使用 CONVERT() 函数(推荐,兼容性好)

CONVERT 支持多种预定义的 style 编码,可快速格式化日期。

常用格式示例:

sql 复制代码
DECLARE @dt DATETIME = '2025-11-14 15:30:45';

-- yyyy-MM-dd(标准日期)
SELECT CONVERT(VARCHAR, @dt, 23);  -- 结果: '2025-11-14'

-- yyyy-MM-dd HH:mm:ss
SELECT CONVERT(VARCHAR, @dt, 120); -- 结果: '2025-11-14 15:30:45'

-- MM/dd/yyyy
SELECT CONVERT(VARCHAR, @dt, 101); -- 结果: '11/14/2025'

-- dd/MM/yyyy
SELECT CONVERT(VARCHAR, @dt, 103); -- 结果: '14/11/2025'

-- yyyy年MM月dd日(需拼接)
SELECT 
    CAST(YEAR(@dt) AS VARCHAR) + '年' +
    RIGHT('0' + CAST(MONTH(@dt) AS VARCHAR), 2) + '月' +
    RIGHT('0' + CAST(DAY(@dt) AS VARCHAR), 2) + '日';
-- 结果: '2025年11月14日'
  1. 使用 FORMAT() 函数(SQL Server 2012+,灵活但性能低)

适合需要自定义格式或本地化显示(如中文)的场景。

sql 复制代码
DECLARE @dt DATETIME = '2025-11-14 15:30:45';

SELECT FORMAT(@dt, 'yyyy-MM-dd');        -- '2025-11-14'
SELECT FORMAT(@dt, 'yyyy/MM/dd');        -- '2025/11/14'
SELECT FORMAT(@dt, 'yyyy年MM月dd日');     -- '2025年11月14日'
SELECT FORMAT(@dt, 'MMM dd, yyyy');      -- 'Nov 14, 2025'
SELECT FORMAT(@dt, 'dddd, MMMM dd', 'zh-CN'); -- '星期五, 十一月 14'

注意:FORMAT() 性能较差,不要在大数据量查询或 WHERE 条件中使用。

  1. 拼接 YEAR() / MONTH() / DAY()(兼容老版本)

适用于 SQL Server 2008 及更早版本,或需要精确控制补零的情况。

sql 复制代码
DECLARE @dt DATE = '2025-11-05';

SELECT 
    CAST(YEAR(@dt) AS VARCHAR(4)) + '-' +
    RIGHT('0' + CAST(MONTH(@dt) AS VARCHAR(2)), 2) + '-' +
    RIGHT('0' + CAST(DAY(@dt) AS VARCHAR(2)), 2) AS FormattedDate;
-- 结果: '2025-11-05'

各方法对比

实际应用示例

场景:按"年月"分组统计订单(高性能写法)

sql 复制代码
SELECT 
    LEFT(CONVERT(VARCHAR, OrderDate, 23), 7) AS YearMonth,
    COUNT(*) AS OrderCount
FROM Orders
GROUP BY LEFT(CONVERT(VARCHAR, OrderDate, 23), 7)
ORDER BY YearMonth;

错误做法(避免!)

sql 复制代码
-- 不要这样写:隐式转换不可靠,且格式依赖系统设置
SELECT '' + GETDATE();  -- 结果不确定!

-- 不要在 WHERE 中用 FORMAT 或 CONVERT 包裹字段
WHERE FORMAT(OrderDate, 'yyyy-MM') = '2025-11';  -- 全表扫描!
相关推荐
TlYf NTLE6 小时前
redis分页查询
数据库·redis·缓存
翻斗包菜6 小时前
MySQL 全量、增量备份与恢复实战指南(含 mysqldump + binlog + XtraBackup)
数据库·oracle
钟智强6 小时前
Linux SSH密码爆破脚本,从原理到实践
linux·运维·ssh
|华|6 小时前
MySQL主从复制与读写分离
数据库·mysql
_下雨天.7 小时前
MySQL 全量、增量备份与恢复
数据库·mysql
TDengine (老段)7 小时前
TDengine IDMP 工业数据建模 —— 数据情景化
大数据·数据库·人工智能·时序数据库·iot·tdengine·涛思数据
Ujimatsu7 小时前
数据分析相关面试题-SQL部分
数据库·sql·数据分析
Omics Pro7 小时前
端到端单细胞空间组学数据分析
大数据·数据库·人工智能·算法·数据挖掘·数据分析·aigc
羊小蜜.7 小时前
Mysql 02:集合函数(聚合函数)查询全解——COUNT/SUM/AVG/MAX/MIN 实战指南
数据库·mysql·集合函数·聚合函数查询
wangjialelele7 小时前
一文读懂 Redis 持久化与事务
linux·数据库·redis·bootstrap