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

参考技术A

语句如下:

--days 是time当月的天数
Select id,time,Days=
TIMESTAMPDIFF(day,time,(DATE_add(time,INTERVAL 1 month))) From 表


--这个方式是给原本时间加一个月和原本时间对比天数差异得来的,还有用计算出月末获取月末的Day得到

本回答被提问者采纳
参考技术B select DAY(LAST_DAY(NOW())),LAST_DAY(NOW()) FROM dual
获取最后一个月的一天的日期 再从该日期获取多少号 就是多少天
其中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查询语句问题 查询当月和上一月的查询语句怎么写?的主要内容,如果未能解决你的问题,请参考以下文章

mysql查询今天,昨天,近7天,近30天,本月,上一月数据

今天昨天近7天近30天本月上一月的SQL

SQL语句查询当月数据

MySQL怎么查询每个月有多少天 详情如下:

sql 怎么查询每一年1到12个月的数据

sql语句 查询一个月的几个周的数据