Mysql Foreach 从一个表到另一个表第 2 部分

标签 mysql date datetime join select

这与我之前的问题有关

Mysql Foreach from one table to another

我设法获取每日日志,但现在我遇到的问题是如何获取过去 5 天的每日日志,格式与单日格式相同

SELECT a.user_id AS EmployeeId, a.username AS EmployeeName, DATE(SUBDATE(NOW(),1)) as Date, TIME_FORMAT(time(min(b.server_time)), '%r') AS 'IN', TIME_FORMAT(time(max(c.server_time)), '%r') as 'OUT'
FROM `users` a
LEFT JOIN user_attendance b ON a.user_id = b.user_id and (b.server_time BETWEEN 
CONCAT(DATE(SUBDATE(NOW(),1)), ' 00:00:00') and CONCAT(DATE(SUBDATE(NOW(),1)), ' 23:59:59')) and b.action = 'IN'
LEFT JOIN user_attendance c ON a.user_id = c.user_id and (b.server_time BETWEEN CONCAT(DATE(SUBDATE(NOW(),1)), ' 00:00:00') and CONCAT(DATE(SUBDATE(NOW(),1)), ' 23:59:59')) and c.action = 'OUT'
GROUP BY a.username, a.user_id

上面的代码用于日常日志。我需要以相同的格式获取 5 天

用户表

userID | username
01     | tiger
02     | pooh

用户出席

user_id | dateTime            | action
01      | 2019-10-01 08:00:00 | IN
01      | 2019-10-01 08:45:00 | OUT
01      | 2019-10-01 10:00:00 | IN
01      | 2019-10-01 14:00:00 | OUT
01      | 2019-10-02 08:00:00 | IN
01      | 2019-10-02 08:45:00 | OUT
01      | 2019-10-02 10:00:00 | IN
01      | 2019-10-02 14:00:00 | OUT
02      | 2019-10-01 08:00:00 | IN
02      | 2019-10-01 08:45:00 | OUT
02      | 2019-10-01 10:00:00 | IN
02      | 2019-10-01 14:00:00 | OUT
02      | 2019-10-02 08:00:00 | IN
02      | 2019-10-02 08:45:00 | OUT
02      | 2019-10-02 10:00:00 | IN
02      | 2019-10-02 14:00:00 | OUT

我期待的结果

user_id | username | IN                  | OUT
01      | tiger    | 2019-10-01 08:00:00 | 2019-10-01 14:00:00
01      | tiger    | 2019-10-02 08:00:00 | 2019-10-02 14:00:00
02      | tiger    | 2019-10-01 08:00:00 | 2019-10-01 14:00:00
02      | tiger    | 2019-10-02 08:00:00 | 2019-10-02 14:00:00

最佳答案

您似乎正在寻找条件聚合:

select 
    u.user_id,
    u.username,
    min(case when a.action = 'IN' then a.dateTime end) `in`,
    max(case when a.action = 'OUT' then a.dateTime end) `out`
from 
    user u
    inner join user_attendance a on u.user_id = a.user_id
group by
    u.user_id,
    u.username,
    date(a.dateTime)
order by
    u.user_id,
    date(a.dateTime)

Demo on DB Fiddle :

| user_id | username | in                  | out                 |
| ------- | -------- | ------------------- | ------------------- |
| 1       | tiger    | 2019-10-01 08:00:00 | 2019-10-01 14:00:00 |
| 1       | tiger    | 2019-10-02 08:00:00 | 2019-10-02 14:00:00 |
| 2       | pooh     | 2019-10-01 08:00:00 | 2019-10-01 14:00:00 |
| 2       | pooh     | 2019-10-02 08:00:00 | 2019-10-02 14:00:00 |

关于Mysql Foreach 从一个表到另一个表第 2 部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58501117/

相关文章:

mysql - 尝试左连接 3 个表,其中 id 可能相同,我通过类型定义它

linux - 如何将纪元转换为 yyyy-mm-ddThh :mm:ss linux

mysql - 在mysql中将varchar字符串数据转换为时间格式

python-3.x - python中人类可读的时区?

python - pytz 时区的行为不一致

php - 如何在php中格式化时间

php - 如何通过 SSL 连接到 Amazon RDS?

MySQL 有些查询永远不会执行

javascript - new Date() 在 Chrome 和 Firefox 中的工作方式不同

oracle - 如何在oracle中将日期转换为时间戳(DD-MON-YYYY HH24 :MI:SS. FF格式)?