搜文章
推荐 原创 视频 Java开发 iOS开发 前端开发 JavaScript开发 Android开发 PHP开发 数据库 开发工具 Python开发 Kotlin开发 Ruby开发 .NET开发 服务器运维 开放平台 架构师 大数据 云计算 人工智能 开发语言 其它开发
Lambda在线 > 秦川以北 > mysql中那些根据时间查询的sql语句

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

秦川以北 2020-07-24

在我们使用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语句








版权声明:本站内容全部来自于腾讯微信公众号,属第三方自助推荐收录。《mysql中那些根据时间查询的sql语句》的版权归原作者「秦川以北」所有,文章言论观点不代表Lambda在线的观点, Lambda在线不承担任何法律责任。如需删除可联系QQ:516101458

文章来源: 阅读原文

相关阅读

关注秦川以北微信公众号

秦川以北微信公众号:gh_acab48ca5b63

秦川以北

手机扫描上方二维码即可关注秦川以北微信公众号

秦川以北最新文章

精品公众号随机推荐