首页 > 数据库 > SQL > 正文

SQL 日期函数如何获取指定日期的星期?

舞夢輝影
发布: 2025-10-08 22:00:01
原创
974人浏览过
答案:不同数据库获取星期几的方法各异,MySQL用DAYOFWEEK或DATE_FORMAT,PostgreSQL用EXTRACT(DOW)或TO_CHAR,SQL Server用DATEPART或DATENAME,中文需CASE转换英文名。

sql 日期函数如何获取指定日期的星期?

在 SQL 中获取指定日期是星期几,可以使用数据库自带的日期函数。不同数据库的语法略有差异,以下是常见数据库的实现方式。

1. 使用 DAYOFWEEK() 或 WEEKDAY() 函数(MySQL)

MySQL 提供了多个函数来获取星期信息:

  • DAYOFWEEK(date):返回 1(星期日)到 7(星期六)
  • WEEKDAY(date):返回 0(星期一)到 6(星期天)
  • DATE_FORMAT(date, '%W'):返回英文星期名,如 'Monday'
  • DATE_FORMAT(date, '%w'):返回 0(星期日)到 6(星期六)
示例:
SELECT 
  DAYOFWEEK('2025-04-05') AS day_of_week,    -- 返回 7(星期六)
  WEEKDAY('2025-04-05') AS weekday_num,       -- 返回 5(星期六)
  DATE_FORMAT('2025-04-05', '%W') AS weekday_name; -- 返回 Saturday
登录后复制

2. 使用 EXTRACT() 函数(PostgreSQL、Oracle、SQLite 等)

PostgreSQL 和 Oracle 支持用 EXTRACT() 提取星期,但需配合 dow(day of week):

  • 返回 0(星期日)到 6(星期六)
示例(PostgreSQL):
SELECT 
  EXTRACT(DOW FROM DATE '2025-04-05') AS day_of_week; -- 返回 6(星期六)
登录后复制

若要获取星期名称:

即构数智人
即构数智人

即构数智人是由即构科技推出的AI虚拟数字人视频创作平台,支持数字人形象定制、短视频创作、数字人直播等。

即构数智人 36
查看详情 即构数智人
SELECT TO_CHAR(DATE '2025-04-05', 'Day') AS weekday_name; -- 返回 Saturday
登录后复制

3. 使用 DATENAME() 和 DATEPART()(SQL Server)

  • DATENAME(WEEKDAY, date):返回星期名称
  • DATEPART(WEEKDAY, date):返回数字(默认 1=星期日,7=星期六)
示例:
SELECT 
  DATEPART(WEEKDAY, '2025-04-05') AS day_number,     -- 返回 7(星期六)
  DATENAME(WEEKDAY, '2025-04-05') AS day_name;       -- 返回 Saturday
登录后复制

4. 获取中文星期(通用思路)

多数数据库不直接返回中文星期,可通过 CASE 语句转换:

SELECT 
  CASE DATE_FORMAT('2025-04-05', '%W')
    WHEN 'Monday' THEN '星期一'
    WHEN 'Tuesday' THEN '星期二'
    WHEN 'Wednesday' THEN '星期三'
    WHEN 'Thursday' THEN '星期四'
    WHEN 'Friday' THEN '星期五'
    WHEN 'Saturday' THEN '星期六'
    WHEN 'Sunday' THEN '星期日'
  END AS chinese_weekday;
登录后复制

基本上就这些方法,根据你使用的数据库选择对应函数即可。注意各数据库对“一周从哪天开始”的定义可能不同,必要时可调整设置。

以上就是SQL 日期函数如何获取指定日期的星期?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号