news 2026/5/7 22:54:41

如何从SQL提取年或月数据_运用YEAR与MONTH提取函数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何从SQL提取年或月数据_运用YEAR与MONTH提取函数

MySQL的YEAR()和MONTH()是标量函数,仅接受DATE/DATETIME/TIMESTAMP类型参数并返回整数,不支持字符串日期或格式化参数;PostgreSQL需用EXTRACT(YEAR FROM col)::INT;WHERE中避免对字段用YEAR/MONTH,应改写为范围查询以走索引。YEAR 和 MONTH 函数在 MySQL 里怎么用直接说结论:MySQL 的 YEAR() 和 MONTH() 是标量函数,只接受一个 DATE、DATETIME 或 TIMESTAMP 类型的参数,返回整数。它们不支持字符串格式的日期(比如 '2024-03'),也不接受格式化参数。常见错误现象:YEAR('2024-03') 看似合理,但实际返回 2024 —— 因为 MySQL 会隐式把字符串转成日期,而 '2024-03' 被当成 '2024-03-01';更危险的是 YEAR('2024/03'),可能转成 0000 或报警告,取决于 SQL 模式。必须确保字段或表达式结果是合法日期类型,不是字符串如果源字段是 VARCHAR 存的 '2024-03-15',得先用 STR_TO_DATE(col, '%Y-%m-%d') 转换,再套 YEAR()MONTH() 返回 1–12,不是 00–12;想补零得自己用 LPAD(MONTH(date_col), 2, '0')PostgreSQL 里没有 YEAR/MONTH 函数,怎么办PostgreSQL 不提供 YEAR() 或 MONTH(),直接调用会报错:ERROR: function year(timestamp without time zone) does not exist。它用的是标准 SQL 的 EXTRACT() 函数。使用场景:你想从 created_at 字段里取年份做分组统计,或者筛选某个月的数据。取年份:用 EXTRACT(YEAR FROM created_at),返回 double precision 类型,常需转成整数:EXTRACT(YEAR FROM created_at)::INT取月份:用 EXTRACT(MONTH FROM created_at)::INT,返回 1–12注意时区影响:created_at 是 TIMESTAMP WITH TIME ZONE 时,EXTRACT 按当前会话时区计算,不是存储时区性能提示:对 EXTRACT(YEAR FROM col) 做 WHERE 或 GROUP BY,无法走普通 B-tree 索引,需要函数索引,比如 CREATE INDEX idx_orders_year ON orders ((EXTRACT(YEAR FROM order_date)::INT));WHERE 条件里用 YEAR/MONTH 容易慢,怎么优化直接写 WHERE YEAR(order_date) = 2024 看似简洁,但几乎所有数据库都会放弃索引扫描,变成全表扫描——因为函数作用于字段,破坏了索引的有序性。 标贝科技 标贝科技-专业AI语音服务的人工智能开放平台

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/7 22:53:35

3分钟手机端刷入Android内核:Horizon Kernel Flasher终极指南

3分钟手机端刷入Android内核:Horizon Kernel Flasher终极指南 【免费下载链接】HorizonKernelFlasher A simple app that can flash AnyKernel flashable zips on android 项目地址: https://gitcode.com/gh_mirrors/ho/HorizonKernelFlasher 还在为刷内核必…

作者头像 李华
网站建设 2026/5/7 22:44:33

Layui弹出层如何实现在关闭时自动刷新底部的父表格

layui.layer.close后需手动调用父页面表格实例的reload方法,关键是在父页面用var tableInstable.render({...})保存实例并挂载到window.parentTable,子页面通过parent.window.parentTable.reload()触发重载。layui.layer.close 后怎么触发父页面表格重载…

作者头像 李华
网站建设 2026/5/7 22:39:29

iPhone USB网络共享驱动一键解决方案:3分钟解决Windows连接难题

iPhone USB网络共享驱动一键解决方案:3分钟解决Windows连接难题 【免费下载链接】Apple-Mobile-Drivers-Installer Powershell script to easily install Apple USB and Mobile Device Ethernet (USB Tethering) drivers on Windows! 项目地址: https://gitcode.c…

作者头像 李华