-
SQL入门必备技能:日期时间格式化、IF 和 CASE 使用解析
- 网站名称:SQL入门必备技能:日期时间格式化、IF 和 CASE 使用解析
- 网站分类:技术文章
- 收录时间:2025-06-08 15:51
- 网站地址:
“SQL入门必备技能:日期时间格式化、IF 和 CASE 使用解析” 网站介绍
在数据库开发和管理中,SQL 是每个开发者必备的技能,而日期时间的格式化与计算、以及如何根据条件返回不同的值,都是我们常常需要用到的功能。在这篇文章中,我将带大家一起学习 SQL 中关于日期时间处理、空值处理和条件判断的常见用法,这些知识对于数据处理和优化查询非常有帮助!
日期时间格式化
1.日期格式化(DATE_FORMAT)
在查询中,有时我们需要以特定的格式来显示日期。使用 DATE_FORMAT 函数,可以灵活地展示日期的不同部分。
常用格式符:
- %y:两位年(如 25)
- %M:完整月名(如 April)
- %D:带后缀的日(如 15th)
示例:
SELECT DATE_FORMAT(NOW(), '%y');
-- 返回当前年份的后两位,例如 '25'
SELECT DATE_FORMAT(NOW(), '%M %y');
-- 返回月名和年份,例如 'April 25'
SELECT DATE_FORMAT(NOW(), '%M %D %y');
-- 返回带后缀的日和年份,例如 'April 15th 25'
2.时间格式化(TIME_FORMAT)
如果我们需要展示时间,可以使用 TIME_FORMAT 来控制时间的显示方式。
常用格式符:
- %H:24小时格式的小时(如 15)
- %i:分钟(如 02)
- %S:秒(如 23)
- %p:AM/PM(如 PM)
示例:
SELECT TIME_FORMAT(NOW(), '%H');
-- 返回当前小时(24小时制),例如 '15'
SELECT TIME_FORMAT(NOW(), '%H:%i %S');
-- 返回当前时间的小时、分钟、秒,例如 '15:02:23'
SELECT TIME_FORMAT(NOW(), '%H %i %S %p');
-- 返回带 AM/PM 的时间,例如 '03 02 23 PM'
日期与时间计算
1.时间加减(DATE_ADD 和 DATE_SUB)
使用 DATE_ADD 可以给日期添加指定的时间间隔,DATE_SUB 则是减去时间间隔。
示例:
SELECT DATE_ADD(NOW(), INTERVAL 1 DAY);
-- 当前时间加1天
SELECT DATE_SUB(NOW(), INTERVAL 1 MONTH);
-- 当前时间减去1个月
2.日期差计算(DATEDIFF)
DATEDIFF 函数用于计算两个日期之间的天数差,返回的结果为整数,正值表示第一个日期晚,负值表示第二个日期晚。
示例:
SELECT DATEDIFF('2002-04-19', '2001-06-19');
-- 返回304,表示两个日期之间有304天的差距
3.时间转秒(TIME_TO_SEC)
TIME_TO_SEC 函数可以将时间转换为秒数,常用于计算两个时间之间的差异。
示例:
SELECT TIME_TO_SEC('9:01');
-- 将时间 '9:01' 转换为秒数,结果为 32460
SELECT TIME_TO_SEC('19:01') - TIME_TO_SEC('18:09');
-- 计算两个时间的差,结果为 3120秒
空值处理
1.IFNULL 和 COALESCE
在 SQL 查询中,IFNULL 和 COALESCE 可以用来处理空值,避免返回 NULL,而是返回一个默认值。
示例:
SELECT IFNULL(shipper_id, 'Not assigned') AS shipper
FROM orders;
-- 如果 shipper_id 为 NULL,则返回 'Not assigned'
SELECT COALESCE(shipper_id, comments, 'Not assigned') AS shipper
FROM orders;
-- 返回第一个非 NULL 值
条件逻辑
1.IF 函数
IF 函数可以根据指定的条件判断,返回不同的结果。
示例:
SELECT order_id, order_date,
IF(YEAR(order_date) = YEAR(NOW()), 'Active', 'Archived') AS Category
FROM orders;
-- 判断订单是否为当前年份,返回 'Active' 或 'Archived'
2.CASE 函数
CASE 是一个更加灵活的条件判断,可以处理多条件的判断逻辑。
示例:
SELECT order_id,
CASE
WHEN YEAR(order_date) = YEAR(NOW()) THEN 'Active'
WHEN YEAR(order_date) = YEAR(NOW()) - 1 THEN 'Last year'
WHEN YEAR(order_date) < YEAR(NOW()) - 1 THEN 'Archived'
ELSE '....'
END AS Category
FROM orders;
-- 根据订单的年份进行分类,当前年标记为 'Active',去年标记为 'Last year'
总结
通过本篇文章的学习,你可以掌握 SQL 中日期时间格式化、时间计算、空值处理和条件逻辑的基本操作。这些技能在处理数据时非常有用,不仅能让你写出更简洁、更高效的查询,还能在日常的数据库操作中大大提高工作效率。
希望今天的分享对你有所帮助!如果你有其他 SQL 使用的技巧或疑问,欢迎在评论区讨论和分享哦!
更多相关网站
- 云服务器:SQL数据库超时的原因与解决方法
- 一个时间戳精度问题,引发了一个MySQL血案
- (二十二) 程序员必备: 10秒到0.1秒,亿级数据下MySQL慢查询分析教程
- MySQL各种SQL的执行频率
- PGSQL提取本月跨越的周数及每周的开始结束日期
- '0000-00-00'日期可以存入MySQL吗
- 【SQL】SQL 语法差异大全(PgSQL/MySQL/Oracle/TiDB/OceanBase)
- 了解SQL吗
- SQL用了两年多,分享2个最常用的小技巧
- 从Sql角度,对比学习Python数据处理包pandas
- SqlServer根据身份证号码查询出生日期和年龄
- 吊打面试官(十一)--Java语言中日期处理相关问题总结
- 玩转MySQL的时间类型:Date、DateTime、TimeStamp、Time
- 多表关联查询的性能优化技巧:预关联
- SQL学习:SQL同比分析案例讲解,一看就懂
- java.util.Date、java.sql.Date、java.sql.Timestamp区别和总结
- 疯传!Java 日期时间底层逻辑大揭秘,看完直接拿捏面试官挖的坑!
- 记一次有意思的 SQL 实现 → 分组后取每组的第一条记录
- 最近发表
-
- JavaScript,ES6,数值扩展,二进制、八进制和十六进制,方法
- 如何用2 KB代码实现3D赛车游戏?2kPlus Jam大赛了解一下
- 10个JavaScript一行代码,解决90%的开发难题
- 如何使用 Fraction.js 解决 BigInt 的计算盲区?
- js四舍五入(js中四舍五入的代码怎么打)
- 全能硬件大师AIDA64 v4.60 最新绿色版下载
- 实用神帖 隔壁老王买到iPhone 6魔改6s,怎么破?
- DIY装机小白的618配机历程(3千元的146K,DDR5无卡方案)2025
- AIDA64 7.30版本发布:改善深色/高对比度模式
- DIY从入门到放弃:CPU没有SN码是保护你
- 标签列表
-
- mydisktest_v298 (35)
- sql 日期比较 (33)
- document.appendchild (35)
- 头像打包下载 (35)
- 二调符号库 (23)
- acmecadconverter_8.52绿色版 (25)
- 梦幻诛仙表情包 (36)
- 魔兽模型 (23)
- java面试宝典2019pdf (26)
- disk++ (30)
- 加密与解密第四版pdf (29)
- iteye (26)
- parsevideo (22)
- centos7.4下载 (32)
- cuda10.1下载 (22)
- intouch2014r2sp1永久授权 (33)
- usb2.0-serial驱动下载 (24)
- jdk1.8.0_191下载 (27)
- axure9注册码 (30)
- virtualdrivemaster (26)
- 数据结构c语言版严蔚敏pdf (25)
- 兔兔工程量计算软件下载 (27)
- 代码整洁之道 pdf (26)
- ccproxy破解版 (31)
- aida64模板 (28)