繁体   English   中英

MySQL-选择当前一周中的最少一天,不一定选择一周中的第一天

[英]MySQL - Select the least day of the current week, not necessarily the first day of the week

使用PHP / MySQL

我正在尝试创建一个select语句,该语句从当前一周的最少一天中获取数据(我正在使用它来显示某位玩家“本周”的数据)。 这个星期从星期日开始。 周日的数据可能并不总是存在的,因此,如果找不到周日数据,则它将使用发现的下一个最早的日期,周一,周二等。

我的日期列名为“ theDate”,数据类型为“ DATE”

查询将类似于:

SELECT *
FROM table_name
WHERE name = '$username'
AND [...theDate = earliest day of data found for the current week week]
LIMIT 1

它将返回一行数据。

这是我尝试获取“本周”数据的查询,它似乎在周日无法正常工作,它什么也没显示:

SELECT *
FROM table_name
WHERE playerName = '$username'
AND YEARWEEK(theDate) = YEARWEEK(CURRENT_DATE)
ORDER BY theDate;

这是我用来获取“本月”数据的查询,即使没有找到本月的第一天,它也可以使用,它将使用当前月/年中发现的最早数据(此查询)最适合我):

SELECT *
FROM table_name
WHERE playerName =  '$username'
AND theDate >= CAST( DATE_FORMAT( NOW(),'%Y-%m-01') AS DATE)
ORDER BY theDate
LIMIT 1

不尝试此操作,您可能需要一个内部查询:

select * 
from table_name tn
where tn.the_date = 
(select min(the_date) 
from table_name 
where WEEKOFYEAR(the_date) = WEEKOFYEAR(CURDATE())
and YEAR(the_date) = YEAR(CURDATE()))

即给我表格中的行,其日期等于当前星期和年份中表格中最早的日期。

请尝试以下操作,将YOUR_DATE替换为所需列中的日期(theDate):

SELECT ADDDATE(YOUR_DATE, INTERVAL 1-DAYOFWEEK(YOUR_DATE) DAY) 
FirstDay from dual


你试过了吗:

SELECT ADDDATE(theDate , INTERVAL 1-DAYOFWEEK(theDate ) DAY) FirstDay
FROM table_name
WHERE playerName =  '$username'
ORDER BY theDate DESC
LIMIT 1

尝试这个

SELECT * FROM table_name WHERE name = '$username' 
AND your_data IS NOT NULL
AND WEEK(the_date,0 = WEEK(NOW(),0))
ORDER BY DATE_FORMAT(the_date,'%w') ASC

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM