mysql查询本周业绩没有星期天_[已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题...

前言

今天又遇到很坑的问题了,因为外国友人每一周的起始日期是周日,跟我们的不一样,我们每一周的起始日期是星期一,这样导致我要用mysql统计一周的数据的时候,对于我们来说,查询的记录包括:上周日的记录+本周的数据到星期六 这样的数据,这就不符合我们的要求,把上周日的数据也统计进来了。

所以也是找了好久的资料,才终于解决

一、问题发现:

默认我一开始写的测试查询本周上周数据的语句是这样的:

#查询本周

select A.sushenum,cast(A.dfdata as DECIMAL (10,3)) dfdatanumber,A.dfdata,

cast(A.dfmoney as DECIMAL (10,3)) dfmoneynumber,A.dfmoney,DATE_FORMAT(A.lrrq,'%Y-%m-%d %H:%i:%S') lrrq

from tablename_test A

where YEARWEEK(date_format(A.lrrq,'%Y-%m-%d')) = YEARWEEK(now())

and A.sushenum = '1309'

#查询上周

select A.sushenum,cast(A.dfdata as DECIMAL (10,3)) dfdatanumber,A.dfdata,

cast(A.dfmoney as DECIMAL (10,3)) dfmoneynumber,A.dfmoney,DATE_FORMAT(A.lrrq,'%Y-%m-%d %H:%i:%S') lrrq

from tablename_test A

where YEARWEEK(date_format(A.lrrq,'%Y-%m-%d')) = YEARWEEK(now())-1

and A.sushenum = '1309'

顺便提一下,查询本周和上周的区别,大家可以对照上面两条sql语句,区别就是

本周是 YEARWEEK(now())-0

上周是 YEARWEEK(now())-1

上上周也就是 YEARWEEK(now())-2,以此类推。

查询到的记录是

e0fdc16a1c58c30d904ea603497021d6.png

大家可以很明显的看到2018年12月2日的记录也查出来了,12月2日是星期日。为了让大家更直观的看,我把12月的月份截出来

5b01303ede975155fba925705d8437a9.png

所以这样查询出来的记录,对于我们来说是有问题的。接下来教大家解决办法。

二、问题解决

可以清楚的知道,mysql查询本周,上周用到的是YEARWEEK()这个函数,具体使用教程可以看链接:http://www.runoob.com/mysql/mysql-functions.html

e82bca00877757a0a9aba86768166088.png

从上面YEARWEEK()函数API可以知道,还有mode这个字段是可以自己设置一周是从星期几开始的,不写的话默认是星期日为一周的开始日期,这里为了适用我们的系统,将星期一设置为一周的开始日期,我们就给mode设为1就可以啦。

修改后:

#查询本周

select A.sushenum,cast(A.dfdata as DECIMAL (10,3)) dfdatanumber,A.dfdata,

cast(A.dfmoney as DECIMAL (10,3)) dfmoneynumber,A.dfmoney,DATE_FORMAT(A.lrrq,'%Y-%m-%d %H:%i:%S') lrrq

from tablename_test A

where YEARWEEK(date_format(A.lrrq,'%Y-%m-%d'),1) = YEARWEEK(now(),1)

and A.sushenum = '1309'

#查询上周

select A.sushenum,cast(A.dfdata as DECIMAL (10,3)) dfdatanumber,A.dfdata,

cast(A.dfmoney as DECIMAL (10,3)) dfmoneynumber,A.dfmoney,DATE_FORMAT(A.lrrq,'%Y-%m-%d %H:%i:%S') lrrq

from tablename_test A

where YEARWEEK(date_format(A.lrrq,'%Y-%m-%d'),1) = YEARWEEK(now(),1)-1

and A.sushenum = '1309'

修改后查询到的记录是:

407aa9d98d02e93fb4b5cc6d01b72267.png

大家可以对比上面的查询记录的图片,可以看到12月2日的这条记录没有了,而是12月3日的这条记录了,至此解决。

三、总结

所以,大家在使用sql函数的时候,一定要看看这个函数的API,这样才能将这个函数使用的融会贯通,比别人更加的掌握。

所以这里考大家一个问题,oracle怎么查询本周、上周的记录呢?

参考文章:

感谢原作者的分享,让技术人能够更快的解决问题

2018年12月31日遇到了问题

今天在用自己测试程序的时候,发现数据都查询不到了,于是赶紧进行排查。发现了一个很大的问题。

什么问题呢,就是当这周是跨了年的时候,mysql用yearweek()会出问题,导致查询不到上周的数据。

上面我也讲到了yearweek()函数的用法。

yearweek(date, mode)会返回年份及第几周(0到53),mode 中 0 表示周天,1表示周一

eb1c22ac00d43161a59425744b4a4ec9.png

8c6768de294c390897fa10ca3b414451.png

大家可以看到,在12月31号的时候,返回的是201901(表示2019年的第一周)

原因就是本周跨年了,所以显示的是2019年的第一周。

f65fbf640f83d50a15e1c5e939ae9cd8.png

但是上文中讲到我去查询上周的时候,用的是YEARWEEK(now())-1

9a32c394fb97563cb6ee8aa5ec317ebd.png

可以看到变成的是201900,但是我要查询上周的数据,也就是12月24日-30日,

e447cce620e331c1a1e42ab8fa36b73b.png

yearweek()返回的值是201851,所以在使用

#查询上周

select A.sushenum,cast(A.dfdata as DECIMAL (10,3)) dfdatanumber,A.dfdata,

cast(A.dfmoney as DECIMAL (10,3)) dfmoneynumber,A.dfmoney,DATE_FORMAT(A.lrrq,'%Y-%m-%d %H:%i:%S') lrrq

from tablename_test A

where YEARWEEK(date_format(A.lrrq,'%Y-%m-%d'),1) = YEARWEEK(now(),1)-1

and A.sushenum = '1309

YEARWEEK(date_format(A.lrrq,'%Y-%m-%d'),1) =YEARWEEK(now(),1)-1的时候,这两者左边是2018**,右边是2019**,是永远也不会相等的

这就遇到很大的问题了,导致上周的数据显示没有。

所以我暂时没有想到解决的办法,后续继续研究一下,先把问题放在这里,有哪位大神解决了的或者有解决思路或者方法的,可以在底部留言或者留下文章链接。我想到解决方法后会继续在本文补充。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值