SQL 常用数据格式化操作方法总结

SQL 常用数据格式化操作方法总结

数据格式化是把日期、数字、字符串 转换成易读、统一格式的核心操作,几乎所有查询都会用到。包含字符串、数字、日期、空值处理、类型转换五大类。


一、字符串格式化(文本处理)

用于清洗、拼接、截取、替换字符串

函数 作用 示例
UPPER() 转大写 UPPER(name)ZHANG
LOWER() 转小写 LOWER(name)zhang
CONCAT() 拼接字符串 CONCAT(姓, ' ', 名)
SUBSTRING() 截取字符 SUBSTRING(phone,1,3) 取前3位
TRIM() 去除首尾空格 TRIM(address)
REPLACE() 替换内容 REPLACE(info,'旧','新')
LEFT()/RIGHT() 左/右截取 LEFT(phone,3)

二、数字格式化(保留小数、补零、取整)

用于金额、百分比、数值显示规范

函数 作用 示例
ROUND() 四舍五入 ROUND(price,2) 保留2位小数
TRUNCATE() 截断不四舍五入 TRUNCATE(3.1415,2)3.14
FORMAT() 千分位+小数 FORMAT(money,2)1,234.56
CEIL()/FLOOR() 向上/向下取整 CEIL(3.1)4
LPAD() 左侧补零/字符 LPAD(id,3,'0')005

三、日期时间格式化(高频重点)

最常用、最容易忘,不同数据库写法略有区别,我给你通用 + 主流数据库版本。

1. 通用标准格式

sql 复制代码
-- 获取 年-月-日
DATE_FORMAT(时间, '%Y-%m-%d')

-- 获取 年-月-日 时:分:秒
DATE_FORMAT(时间, '%Y-%m-%d %H:%i:%s')

2. 主流数据库日期格式化

  • MySQLDATE_FORMAT(时间, '%Y-%m-%d')
  • SQL ServerCONVERT(varchar, 时间, 23)
  • OracleTO_CHAR(时间, 'YYYY-MM-DD')

常用格式符(MySQL)

符号 含义
%Y 4位年(2025)
%m 2位月(01-12)
%d 2位日
%H 24小时制
%i 分钟
%s

日期提取

sql 复制代码
YEAR(create_time)    -- 提取年
MONTH(create_time)   -- 提取月
DAY(create_time)     -- 提取日
HOUR(create_time)    -- 提取小时

四、空值格式化(把 NULL 变成默认值)

查询时把空值显示为 0未知,避免报表显示 NULL 很难看

函数 作用
IFNULL(字段, 默认值) MySQL 空值替换
COALESCE(字段, 默认值) 通用标准(所有数据库都能用)

示例:

sql 复制代码
-- 没有金额就显示 0
COALESCE(money, 0)

-- 没有备注就显示"无"
COALESCE(remark, '无')

五、数据类型转换(强制转格式)

把字符串转数字、日期转字符串、数字转字符串等

函数 作用
CAST(值 AS 类型) 通用类型转换
CONVERT() 转换(SQL Server/MySQL)

示例:

sql 复制代码
CAST(score AS CHAR)   -- 数字转字符串
CAST('123' AS INT)    -- 字符串转数字

高频实用格式化模板(直接用)

  1. 金额显示:保留2位小数

    sql 复制代码
    ROUND(price, 2)
  2. 手机号隐藏中间4位

    sql 复制代码
    CONCAT(LEFT(phone,3), '****', RIGHT(phone,4))
  3. 日期只显示 年-月-日

    sql 复制代码
    DATE_FORMAT(create_time, '%Y-%m-%d')
  4. 空值显示为 0

    sql 复制代码
    COALESCE(score, 0)
  5. 数字补零成固定长度

    sql 复制代码
    LPAD(id, 4, '0')  → 0012

总结

  1. 字符串 :用 UPPER/LOWER/CONCAT/SUBSTRING/REPLACE 清洗文本
  2. 数字 :用 ROUND/FORMAT/LPAD 控制小数、千分位、补零
  3. 日期 :用 DATE_FORMAT年-月-日,是最常用格式化
  4. 空值 :用 COALESCE 把 NULL 变成默认值
  5. 类型转换 :用 CAST 强制转换数据格式
相关推荐
TE-茶叶蛋5 小时前
数据库-引用完整性(referential integrity)
数据库
IronMurphy5 小时前
MySQL拷打第二讲
数据库·mysql
裴东青7 小时前
ProxySQL实现MySQL主从集群的读写分离
数据库·mysql·adb
handler017 小时前
【MySQL】教你库与表的增删查改操作(基础)
运维·数据库·笔记·sql·mysql·数据·分析
姚不倒8 小时前
从零实现一个基于 Ollama + Go + MySQL 的 Text-to-SQL 智能体(M1 实战)
sql·mysql·云原生·golang
染指11108 小时前
9.LangChain框架(实现RAG)
数据库·人工智能·算法·机器学习·ai·大模型
2401_873479408 小时前
主流IP离线库(IP数据云、纯真、IPIP.NET)怎么选?全面对比分析
服务器·网络·数据库
毋语天8 小时前
Redis 零基础实战指南:从核心原理到生产落地的完整路线
数据库·redis·缓存
weixin_408318049 小时前
教育行业直播系统搭建指南
java·大数据·数据库