首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySQL- -如何查询以获取特定年份之间的行

MySQL- -如何查询以获取特定年份之间的行
EN

Stack Overflow用户
提问于 2017-11-15 22:58:12
回答 3查看 42关注 0票数 0

我试着回到介于年份之间的行,比如从0到5年,5-10年,10-15年等等。

到目前为止,我只能在0-5之间生产产品,但是在5-10年之间的查询方面需要一些帮助等等。

代码语言:javascript
运行
复制
SELECT * 
FROM users 
WHERE start_date >= DATE_SUB(NOW(),INTERVAL 5 YEAR)

我试过使用中间函数,但可能使用不正确。愿意接受建议。

我不喜欢为日期编写硬编码值,因为我不想每隔几年就去修改一次。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-11-15 23:03:19

假设start_date是日期数据类型(不是日期时间或时间戳)

五年前至今

代码语言:javascript
运行
复制
 WHERE start_date >  DATE(NOW()) + INTERVAL -5 YEAR
   AND start_date <= DATE(NOW()) + INTERVAL  0 YEAR

十年前到五年前

代码语言:javascript
运行
复制
 WHERE start_date >  DATE(NOW()) + INTERVAL -10 YEAR
   AND start_date <= DATE(NOW()) + INTERVAL -5  YEAR
票数 1
EN

Stack Overflow用户

发布于 2017-11-15 23:03:17

您可以使用BETWEEN

代码语言:javascript
运行
复制
SELECT *
FROM users
WHERE (start_date BETWEEN NOW() AND DATE_SUB(NOW(), INTERVAL 5 YEAR))

然后在你的下一次间歇:

代码语言:javascript
运行
复制
SELECT *
FROM users
WHERE (start_date BETWEEN DATE_SUB(NOW(), INTERVAL 5 YEAR) AND DATE_SUB(NOW(), INTERVAL 10 YEAR))
票数 1
EN

Stack Overflow用户

发布于 2017-11-15 23:05:05

0-5

代码语言:javascript
运行
复制
SELECT * FROM users
WHERE
start_date BETWEEN (CURDATE() - INTERVAL 5 YEAR) AND CURDATE();

5- 10

代码语言:javascript
运行
复制
SELECT * FROM users
WHERE
start_date BETWEEN (CURDATE() - INTERVAL 10 YEAR) AND (CURDATE() - INTERVAL 5 YEAR);

10 - 15

代码语言:javascript
运行
复制
SELECT * FROM users
WHERE
start_date BETWEEN (CURDATE() - INTERVAL 15 YEAR) AND (CURDATE() - INTERVAL 10 YEAR);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47318743

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档