MYSQL查询语句问题 查询当月和上一月的查询语句怎么写?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MYSQL查询语句问题 查询当月和上一月的查询语句怎么写?相关的知识,希望对你有一定的参考价值。
select * from shipmentlist,shipmentscrib where (shipmentlist.shipmentlistno=shipmentscrib.shipmentlistno) and (year(shipmentlist.shipmentdate)=year(now())) and (month(shipmentlist.shipmentdate)=month(now()) or month(shipmentlist.shipmentdate)=month(now())-1 ) ORDER BY shipmentdate DESC
参考技术A select*
from
shipmentlist,shipmentscrib
where
(shipmentlist.shipmentlistno=shipmentscrib.shipmentlistno)
and (year(shipmentlist.shipmentdate)=year(now()))
and (month(shipmentlist.shipmentdate)=month(now())
or month(shipmentlist.shipmentdate)=month(now())-1 )
ORDER BY shipmentdate DESC
格式化了一下你的SQL,分析一下。
假如今天是 2012年1月1日。
那么上面的条件。
将变为
year = 2012 and month = 1 OR month = 0
其实,对于 查询 当月和上一月
相当于
shipmentlist.shipmentdate >= 上月的1号
AND shipmentlist.shipmentdate < 下月的1号
LAST_DAY(NOW()) 可以获取 本月的最后一天.
DATE_ADD( LAST_DAY(NOW()) INTERVAL 1 DAY ) 可以获取下月第一天。
DATE_SUB ( DATE_ADD( LAST_DAY(NOW()) INTERVAL 1 DAY ) INTERVAL 2 MONTH ) 可以获取上月的1号
(也就是用 下月的1号 减少2个月,从而获取 上月的1号)
最后 SQL 修改为:
select
*
from
shipmentlist,shipmentscrib
where
(shipmentlist.shipmentlistno=shipmentscrib.shipmentlistno)
and shipmentlist.shipmentdate >= DATE_SUB ( DATE_ADD( LAST_DAY(NOW()) INTERVAL 1 DAY ) INTERVAL 2 MONTH )
AND shipmentlist.shipmentdate < DATE_ADD( LAST_DAY(NOW()) INTERVAL 1 DAY )
ORDER BY shipmentdate DESC本回答被提问者采纳 参考技术B 查询当月和上个月的数据:
select * from demo where date_format(date,'%Y-%m-%d')=current_date()
union all
select * from demo where year(date)=year(now()) and month(date)= month(subdate(curdate(), INTERVAL 1 month));
MySQL怎么查询每个月有多少天 详情如下:
表:order
字段:id,time 序号,时间
数据:1,“2016-04-01”
2,“2016-05-15”
3,“2016-04-15”
怎么求出数据中的月份每月有多少天,求助!
最后答案是: 4月 5月
30 31
语句如下:
Select id,time,Days=
TIMESTAMPDIFF(day,time,(DATE_add(time,INTERVAL 1 month))) From 表
--这个方式是给原本时间加一个月和原本时间对比天数差异得来的,还有用计算出月末获取月末的Day得到
获取最后一个月的一天的日期 再从该日期获取多少号 就是多少天
其中NOW() 替换为
1,“2016-04-01”
2,“2016-05-15”
3,“2016-04-15”
例如
select DAY(LAST_DAY(NOW())),LAST_DAY('2016-04-01') FROM dual
以上是关于MYSQL查询语句问题 查询当月和上一月的查询语句怎么写?的主要内容,如果未能解决你的问题,请参考以下文章