sql >> Database >  >> RDS >> Mysql

Mysql Forreach van de ene tafel naar de andere Deel 2

Het lijkt erop dat u op zoek bent naar voorwaardelijke aggregatie:

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 op 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 |


  1. SQL-query om verschillende waarden van alle kolomwaarden in een tabel te krijgen

  2. DMZ maken voor EBS R12

  3. Hoe stel ik een standaardrij in voor een query die geen rijen retourneert?

  4. de waarde uit de kolom halen, maar null retourneren?