当前位置:首页 > 数据库 > [已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题

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

2022年08月06日 08:18:15数据库6

前言

今天又遇到很坑的问题了,因为外国友人每一周的起始日期是周日,跟我们的不一样,我们每一周的起始日期是星期一,这样导致我要用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,以此类推。

查询到的记录是

[已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题 _ JavaClub全栈架构师技术笔记

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

[已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题 _ JavaClub全栈架构师技术笔记

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

 

二、问题解决

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

[已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题 _ JavaClub全栈架构师技术笔记

 

从上面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'

修改后查询到的记录是:

[已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题 _ JavaClub全栈架构师技术笔记

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

 

三、总结

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

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

 

 

参考文章:

https://blog.csdn.net/qq_21995733/article/details/78989074

https://www.cnblogs.com/xgwtzg/p/6140022.html

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

 


2018年12月31日遇到了问题

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

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

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

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

[已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题 _ JavaClub全栈架构师技术笔记[已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题 _ JavaClub全栈架构师技术笔记

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

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

[已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题 _ JavaClub全栈架构师技术笔记

 

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

[已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题 _ JavaClub全栈架构师技术笔记

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

[已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题 _ JavaClub全栈架构师技术笔记

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**,是永远也不会相等的

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

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

作者:小小鱼儿小小林
来源链接:https://blog.csdn.net/qq_27471405/article/details/84935791

版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。


本文链接:https://www.javaclub.cn/database/18314.html

标签: MySQL
分享给朋友:

“[已解决]mysql查询一周内的数据,解决一周的起始日期是从星期日(星期天|周日|周天)开始的问题” 的相关文章

一文带你了解MySQL基础

目录 一,为什么要学习数据库 二,数据库的相关概念 2.1数据库术语...

MySQL面试有这一篇就够了

MySQL面试有这一篇就够了

MySQL面试常见知识点 1、 MySQL常用的存储引擎有什么?它们有什么区别? InnoDB InnoDB是MySQL的默认存储引擎,支持事务、行锁和外键等操作。 MyISAM MyISAM是M...

MySQL数据库(基础)

MySQL数据库(基础)

目录 1. 数据库概念 1.1 数据库是干嘛的? 1.2 数据库和数据结构是啥关系? ​1.3 两种类型的数据库 2. MySQL数据库 2.1 MySQL数据库概念 2.2 MySQL基本操作  2.2.1 建立...

MySQL事务和锁

MySQL事务和锁

1.事务 1.什么是事务? 事务: 要么全部成功,要么全部失败 事务是数据库管理系统(DBMS)执行过程中的一个 逻辑单位 ,由一个 有限的数据库操作序列 组成。 逻辑单位:最小的操作单位,不可再分割。 有限的数据库操作序列:...

JDBC连接时所犯错误1.字符集设置不合适2.连接MySQL8.0社区版时时区不一致3..包名不能以Java.命名4.驱动被弃用

Microsoft JDBC Driver 的主页为:https://msdn.microsoft.com/en-us/data/aa937724.aspx 下载所需驱动 今天连接时报了四次错,记录下来 1.java.sql.SQLException:...

JDBC如何连接mysql数据库附详细步骤

JDBC如何连接mysql数据库附详细步骤

JDBC连接数据库在学习中是很重要的一个环节,今天给大家详细说明JDBC连接数据库需要的步骤 1.加载驱动 驱动包的下载地址 https://dev.mysql.com/downloads/connector/j/ 到时候要将这个加载到项目中然后输入...

Linux (centos8)安装 MySQL 8 数据库(图文详细教程)

Linux (centos8)安装 MySQL 8 数据库(图文详细教程)

我的公众号 今天2021年4月23日。我买了阿里云centos服务器,安装mysql8.0,做一笔记,以供大家使用。 本教程手把手教你如何在 Linux 安装 MySQL 数据库,以 CentOS 8为例。 1. 下载并...

性能优化|深入理解mysql索引数据结构与算法

性能优化|深入理解mysql索引数据结构与算法

什么是索引? 在mysql中,索引就是帮助mysql快速找到某条数据的一种数据结构,它是排好序的,独立于mysql表数据之外的。 索引数据结构分为哪几种 二叉树、红黑树、Hash表、B树。 在这里我们主要介绍hash表和B树...

mysql|mysql删除重复数据,一条sql就搞定

SQL 逻辑: 首先找出所有重复的sku_id 在找出这些sku_id中关联的主键id最大的一条记录(用来保留,不删除) 两个sql合并 就可以筛选出来最终需要删除的id select id from sku_and...

mysql查询最新的一条记录

mysql查询最新的一条记录

数据库记录: MYSQL查询不同用户 最新的一条记录 方法1:查询出结果后将时间排序后取第一条(只能取到一条,并且不能查询不同客户的记录) SELECT CUSTOMER_ID,CONTENT,MODIFY_TIME FROM `ser...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。