本日の各部屋の空き状況を求める SQL を作っています。
(かなりデフォルメしています)
lang
1DROP TABLE IF EXISTS facilities, pc_logs; 2 3CREATE TABLE facilities( 4 id INT -- 部屋番号 5 , room_name TEXT -- 部屋の名前 6 , capacity INT -- 収容人員 7); 8INSERT INTO facilities(id , room_name , capacity) VALUES 9 (1, 'r1', 40), (2, 'r2', 50), (3, 'r3', 30); 10SELECT * FROM facilities; 11 id | room_name | capacity 12----+-----------+---------- 13 1 | r1 | 40 14 2 | r2 | 50 15 3 | r3 | 30 16(3 行) 17 18CREATE TABLE pc_logs( 19 id INT -- 連番 20 , room_id INT -- 部屋番号 21 , login TIMESTAMP -- ログイン時刻 22); 23INSERT INTO pc_logs( id , room_id , login) VALUES 24 (1, 1, '2015/06/01 09:00:00'), 25 (2, 2, '2015/06/02 09:10:00'), 26 (3, 2, '2015/06/02 09:20:00'), 27 (4, 2, '2015/06/02 09:30:00'), 28 (5, 2, '2015/06/02 09:40:00'); 29SELECT * FROM pc_logs; 30 id | room_id | login 31----+---------+--------------------- 32 1 | 1 | 2015-06-01 09:00:00 33 2 | 2 | 2015-06-02 09:10:00 34 3 | 2 | 2015-06-02 09:20:00 35 4 | 2 | 2015-06-02 09:30:00 36 5 | 2 | 2015-06-02 09:40:00 37(5 行)
求める結果:
lang
1 facility_id | room_name | occupied | capacity 2-------------+-----------+----------+---------- 3 1 | r1 | 0 | 40 4 2 | r2 | 4 | 50 5 3 | r3 | 0 | 30 6(1 行)
書いてみた SQL:
lang
1SELECT 2 facilities.id AS facility_id -- 部屋番号 3 , facilities.room_name AS room_name -- 部屋の名前 4 , COUNT(pc_logs.*) AS occupied -- 利用者数 5 , facilities.capacity AS capacity -- 収容人員 6FROM facilities 7LEFT OUTER JOIN pc_logs ON(facilities.id = pc_logs.room_id) 8WHERE login >= '2015/06/02' 9GROUP BY facility_id, room_name, capacity 10ORDER BY facility_id 11; 12 facility_id | room_name | occupied | capacity 13-------------+-----------+----------+---------- 14 2 | r2 | 4 | 50 15(1 行)
WHERE 句が先に適用されるためこうなってしまうんだと思うのですが、
どう書けばよいか教えてください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2015/06/02 01:55