mysql中那些根据时间查询的sql语句
在我们使用mysql是免不了要根据时间去查询一些数据,这个时候一般有几种方式可以去查询。
第一种数据库,如果有数据新建时间可以以这个时间为节点,通过当前时间条件去比较时间来查询到此段时间内的数据
例如:这个是可传参数的
SELECT * FROM 表名 a WHERE
AND DATE_FORMAT(a.out_date,'%Y-%m-%d %H:%i:%S') >= DATE_FORMAT(#{beginOutPoundDate},'%Y-%m-%d %H:%i:%S')
AND DATE_FORMAT(a.out_date,'%Y-%m-%d %H:%i:%S') <= DATE_FORMAT(#{endOutPoundDate},'%Y-%m-%d %H:%i:%S')
不过如果指定就查询一天之内或者一周之内的数据那又如何?
不慌来上菜:
1.查询一天之内的数据时间从今天的零0点0分0秒开始---到23点59分59秒结束,查询完在给他按更新时间排个序!!
SELECT * FROM 表名 a
WHERE a.out_date >= DATE_FORMAT(CURDATE(),'%Y-%m-%d %H:%i:%s')
AND a.out_date <= DATE_SUB( DATE_ADD(CURDATE(), INTERVAL 1 DAY),INTERVAL 1 SECOND)
ORDER BY a.update_date ASC
2.查询一周内的数据:有有条件的有没条件的 还有上周的
-- 有条件SELECT * FROM 表名 a WHERE DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(a.out_date)
-- 没条件
select * from Tabel名 where 时间字段名 between current_date()-7 and sysdate()
上周SELECT * FROM 表名 WHERE YEARWEEK(date_format(时间字段名,'%Y-%m-%d')) = YEARWEEK(now())-1;
3.查询一个月内数据
SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(时间字段名)
4.查询本月的数据
SELECT * FROM 表名 WHERE DATE_FORMAT( 时间字段名, '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' )
5.查询上个月的数据
SELECT * FROM 表名 WHERE PERIOD_DIFF( date_format( now( ) , '%Y%m' ) , date_format( 时间字段名, '%Y%m' ) ) =1
6.查询当前6个月前的数据
SELECT * FROM 表名 WHERE 时间字段名 between date_sub(now(),interval 6 month) and now();
7.查询多少秒内的数据
SELECT count( * ) AS c, sum( if( logusertype = 2, logusertype, 0 ) ) / 2 AS a, sum( if( logusertype = 3, logusertype, 0 ) ) /3 AS b
FROM testlog WHERE UNIX_TIMESTAMP(NOW())-UNIX_TIMESTAMP( logendtime )<=30
8.查询一年的数据
-- 查询一年的
SELECT * FROM table_name WHERE condition1 AND condition2 AND DATE_SUB(CURDATE(), INTERVAL 1 YEAR) <= date(column_name);
-- 查询一年的
select * from 表名 where year(create_date)=year(now());
-- 查询上年的
select * from 表名 where year(create_date)=year(date_sub(now(),interval 1 year));
9.查询昨天的数据(只有昨天的)还有只包括昨天和今天的
-- 只有昨天的
SELECT * FROM 表名 WHERE DATEDIFF(字段,NOW())=-1; -- 同理,查询前天的就是-2
-- 包括昨天和今天的
SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( 时间字段名) <= 1
10.查询本季的和上季的数据
-- 本季度
select * from 表名 where quarter(create_date)=quarter(now());
-- 上季度
select * from 表名 where quarter(create_date)=quarter(date_sub(now(),interval 1 quarter));