以下のスキーマから、私のデータベースの従業員の日中/時間を照会したいと思います。出席者:柔軟なスケジュールのtime_inとtime_outを取得する従業員
注:従業員のスケジュールは柔軟性があり、夜間シフトまたは日シフト(従業員#1で見ることができるように)で作業できます。
スキーマ:出席テーブル
| id | employee_id | timedata | in_out |
|----|-------------|---------------------|--------|
| 1 | 1 | 2017-06-08 13:51:02 | IN | <- night shift (inserted: 2017-06-08)
| 2 | 1 | 2017-06-09 01:10:04 | OUT | <- actual time_out (inserted: 2017-06-09)
| 3 | 1 | 2017-06-09 14:11:40 | IN |
| 4 | 1 | 2017-06-09 19:41:26 | OUT |
| 5 | 2 | 2017-06-08 09:25:17 | IN |
| 6 | 2 | 2017-06-08 20:44:14 | OUT |
| 7 | 2 | 2017-06-09 11:35:00 | IN |
| 8 | 2 | 2017-06-09 20:36:06 | OUT |
これは私がこれまで行ってきたクエリです:
SELECT employee_id,
DATE(timedata) as attendance_date,
MIN(IF(in_out='IN',timedata,NULL)) AS time_in,
MAX(IF(in_out='OUT',timedata,NULL)) AS time_out
FROM attendances
GROUP BY employee_id,DATE(timedata)
このクエリでの問題は、私はのTIME_OUTを得ることができないということですナイトシフト取引。
| employee_id | attendance_date | time_in | time_out |
|-------------|-----------------|---------------------|---------------------|
| 1 | 2017-06-08 | 2017-06-08 13:51:02 | NULL |
| 2 | 2017-06-08 | 2017-06-08 11:25:17 | 2017-06-08 20:44:14 |
| 2 | 2017-06-09 | 2017-06-09 11:35:00 | 2017-06-09 20:36:06 |
| 1 | 2017-06-09 | 2017-06-09 14:11:40 | 2017-06-09 19:41:26 |
ここにある私の 所望の出力
| employee_id | attendance_date | time_in | time_out |
|-------------|-----------------|---------------------|---------------------|
| 1 | 2017-06-08 | 2017-06-08 13:51:02 | 2017-06-09 01:10:04 |
| 2 | 2017-06-08 | 2017-06-08 09:25:17 | 2017-06-08 20:44:14 |
| 1 | 2017-06-09 | 2017-06-09 14:11:40 | 2017-06-09 19:41:26 |
| 2 | 2017-06-09 | 2017-06-09 11:35:00 | 2017-06-09 20:36:06 |
任意の提案が高く評価されています。これは、出力されます。