mysql 查询当天、本周,本月,上一个月的数据
分类:计算机 | 数据库 | MySQL | 综合 1067
更新:2021-02-24 11:53:08编辑
转载地址
https://www.jb51.net/article/133943.htm
今天
select * from 表名 where to_days(时间字段名) = to_days(now());
昨天
SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( 时间字段名) <= 1
近7天
SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(时间字段名)
近30天
SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(时间字段名)
本月
SELECT * FROM 表名 WHERE DATE_FORMAT( 时间字段名, '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' )
上一月
SELECT * FROM 表名 WHERE PERIOD_DIFF( date_format( now( ) , '%Y%m' ) , date_format( 时间字段名, '%Y%m' ) ) =1
查询本季度数据
select * from `ht_invoice_information` where QUARTER(create_date)=QUARTER(now()) and YEAR(create_date)=YEAR(NOW());
注意:本季度同时也是本年,所以也要判断时间是不是本年的,然后再去判断是不是本季度
说明:1-3月是第一季度,4-6月是第二季度,7-9月是第三季度,10-12月是第四季度。
QUARTER()函数返回给定日期值(1到4之间的数字)的一年中的季度。
- 1月至3月返回1
- 4月至6月返回2
- 7月至9月返回3
- 10月至12月返回4
示例:
SELECT QUARTER("2017-06-15");
返回的是2
查询上季度数据
select * from `ht_invoice_information` where QUARTER(create_date)=QUARTER(DATE_SUB(now(),interval 1 QUARTER));
查询本年数据
select * from `ht_invoice_information` where YEAR(create_date)=YEAR(NOW());
查询上一年数据
select * from `ht_invoice_information` where year(create_date)=year(date_sub(now(),interval 1 year));
猿导航
阅读排行榜
- 1vue和el-table使用经验-如何刷新表格数据10936
- 2three.js加载3D瓦片和3dtiles数据生成交互式地图的开源项目9481
- 3Microsoft Visual C++ Redistributable是什么,有什么作用?7252
- 4mybatis使用经验——mybatis-spring-boot-starter和mybatis的版本对应关系表(持续更新~)5823
- 5uni-app使用经验—vue页面和html页面如何互相调用接口并传参5468
- 6Spring学习经验—@ResponseBody注解的使用说明4870
- 7Intellij IDEA下的版本控制VCS的启用与关闭4868
- 8Druid异常解决经验—java.sql.SQLException url not set4499
- 9如何用批处理命令(bat脚本)启动和停止windows服务4266
- 10nuxt.js项目中如何添加和使用全局变量4134
- 11解决SpringBoot使用maven下载不了jar包的问题3481
- 12linux中解压tar.gz文件报错“gzip: stdin: invalid compressed data--format violated”3386
- 13nuxtjs asyncData使用经验—如何发起多个axios请求并携带参数3236
- 14在Nuxt.js项目的head中引用外部js文件3080
- 15在NVIDIA控制面板设置参数时提示“拒绝访问 无法应用选定的设置到您的系统”的解决方法之一3056