vlambda博客
学习文章列表

mysql中那些根据时间查询的sql语句


在我们使用mysql是免不了要根据时间去查询一些数据,这个时候一般有几种方式可以去查询。

第一种数据库,如果有数据新建时间可以以这个时间为节点,通过当前时间条件去比较时间来查询到此段时间内的数据

例如:这个是可传参数的

SELECT * FROM 表名 a WHEREAND 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 表名 aWHERE 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 bFROM 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));
mysql中那些根据时间查询的sql语句