質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

1回答

1616閲覧

存在しない行も含めてカウント

hotta

総合スコア1613

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2015/06/02 01:40

本日の各部屋の空き状況を求める 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 句が先に適用されるためこうなってしまうんだと思うのですが、
どう書けばよいか教えてください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

変更前
WHERE login >= '2015/06/02'
変更後
AND pc_logs.login >= '2015/06/02'

ではいかがでしょう?
結合先データで存在しないデータになっていれば
LEFT OUTER JOINでない項目がNULLで結合するはずです

投稿2015/06/02 01:49

kutsulog

総合スコア985

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hotta

2015/06/02 01:55

ON(条件) の後に AND で追加条件を書けるんですね。。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問