音乐吧 - www.52290.com

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 1439|回复: 0

MySQL - 查询今天的数据(以及昨天、本月、上个月、今年...)

[复制链接]

1056

主题

1090

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

音乐币
101
贡献
537
金钱
4385
威望
2120
相册
1

推广达人宣传达人突出贡献荣誉管理最佳新人活跃会员

QQ
发表于 2017-7-11 21:00:32 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?注册

x
假设我们有一张简单的订单表(order
20170712135949.png

建表语句如下:
  1. CREATE TABLE `order` (
  2.   `id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
  3.   `order_name` VARCHAR(45) NOT NULL,
  4.   `order_time` DATETIME NOT NULL,
  5.   PRIMARY KEY (`id`)
  6. )
复制代码
下面根据 order_time 字段来查询各个时间段内的所有记录。1,查询当天(今天)的数据
  1. SELECT * FROM `order` WHERE TO_DAYS(order_time) = TO_DAYS(NOW())
复制代码
2,查询昨天的数据
  1. SELECT * FROM `order` WHERE TO_DAYS(NOW()) - TO_DAYS(order_time) = 1
复制代码
3,查询最近7天的数据(包括今天一共7天)
  1. SELECT * FROM `order` where DATE_SUB(CURDATE(), INTERVAL 7 DAY) < date(order_time)
复制代码
4,查询最近30天的数据(包括今天一共30天)
  1. SELECT * FROM `order` where DATE_SUB(CURDATE(), INTERVAL 30 DAY) < date(order_time)
复制代码
5,查询当月(本月)的数据
  1. SELECT * FROM `order` WHERE DATE_FORMAT(order_time, '%Y%m') = DATE_FORMAT(CURDATE(), '%Y%m')
复制代码
6,查询上个月的数据
  1. SELECT * FROM `order` WHERE PERIOD_DIFF(DATE_FORMAT(NOW(),'%Y%m'), DATE_FORMAT(order_time,'%Y%m')) =1
复制代码

7,查询本季度的数据
  1. SELECT * FROM `order` WHERE QUARTER(order_time)=QUARTER(NOW())
复制代码

8,查询上季度的数据
  1. SELECT * FROM `order` WHERE QUARTER(order_time)=QUARTER(DATE_SUB(NOW(),INTERVAL 1 QUARTER))
复制代码
9,查询当年(今年)的数据
  1. SELECT * FROM `order` WHERE YEAR(order_time)=YEAR(NOW())
复制代码
10,查询去年的数据
  1. SELECT * FROM `order` WHERE YEAR(order_time)=YEAR(DATE_SUB(NOW(),INTERVAL 1 YEAR))
复制代码



您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|手机版|Archiver|版权声明| 音乐吧 52290 ( 桂ICP备2021006182号 )

GMT+8, 2024-4-30 02:08 , Processed in 0.048859 second(s), 28 queries .

Powered by Discuz! X3.4

© 2001-2023 07726.Com Inc.

快速回复 返回顶部 返回列表