百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文
SQL入门必备技能:日期时间格式化、IF 和 CASE 使用解析

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 使用的技巧或疑问,欢迎在评论区讨论和分享哦!