mysql如何提取日期中的年份_使用year函数从日期中截取

YEAR()函数仅支持DATE/DATETIME/TIMESTAMP类型,字符串需用STR_TO_DATE()显式转换;INT型年月日应取整除10000;WHERE中使用YEAR()会导致索引失效,应改用日期范围查询。YEAR() 函数直接提取年份,但要注意输入类型MySQL 的 YEAR() 函数只接受 DATE、DATETIME 或 TIMESTAMP 类型值,传入字符串会触发隐式转换------看似能用,实则埋雷。比如 '2023-10-05' 这种标准格式能转成功,但 '05/10/2023' 或 '20231005' 很可能转成 0000 或报错。安全做法是先用 STR_TO_DATE() 显式转成日期,再套 YEAR(),例如:YEAR(STR_TO_DATE('05/10/2023', '%d/%m/%Y'))如果字段本身就是 DATE 类型(如 order_date),直接写 YEAR(order_date) 最稳对 INT 类型存的 20231005 这种,别硬套 YEAR(),改用 FLOOR(col / 10000)WHERE 条件里用 YEAR() 可能导致索引失效在查询条件中写 WHERE YEAR(create_time) = 2023,哪怕 create_time 有索引,MySQL 通常也无法有效利用------因为函数作用于列,优化器没法做范围下推。 Genspark Super Agent Genspark AI推出的通用AI智能体引擎

相关推荐
花酒锄作田4 小时前
Pydantic校验配置文件
python
hboot4 小时前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络
GBASE9 小时前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
ZhengEnCi15 小时前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi16 小时前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
曲幽16 小时前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南
python·fastapi·web·graphql·route·cors·rest·strawberry
用户83580861879117 小时前
基于 Self-RAG 与列表级重排序的进阶 RAG 系统设计与实现
python
xiezhr19 小时前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
Warson_L1 天前
Python `Annotated` 与 LangGraph Reducer 学习笔记
python
韩师傅1 天前
海天线算法的前世今生
python·计算机视觉