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

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

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

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

Q&A

解決済

3回答

2995閲覧

postgreSQL 固定行を取得したい

xx_6_6_xx

総合スコア42

PostgreSQL

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

0グッド

0クリップ

投稿2019/05/17 02:51

前提・実現したいこと

1つの商品名につき、データの有無は関係なく
必ず対象日2行分抽出する。

というのはできるのでしょうか…?

例えばこういうテーブルがあったとして

【商品テーブル】

商品ID商品名対象日個数
001りんご2019-11-3010
001りんご2019-01-3110
001りんご2019-02-2830
002みかん2018-12-3120
002みかん2019-01-3120
002みかん2019-02-2810
003いちご2019-02-2820

postgreSQL

1select * from 商品テーブル 2where 対象日 = '2019-01-31' or 対象日 = '2019-02-28'

とするとこうなりますよね・・・

【抽出結果】

商品ID商品名対象日個数
001りんご2019-01-3110
001りんご2019-02-2830
002みかん2019-01-3120
002みかん2019-02-2810
003いちご2019-02-2820

それを↓こうしたいです。。
【003|いちご|2019-01-31 を追加】

商品ID商品名対象日個数
001りんご2019-01-3110
001りんご2019-02-2830
002みかん2019-01-3120
002みかん2019-02-2810
003いちご2019-01-31NULL
003いちご2019-02-2820

つまり

空行を追加 or 固定行を取得 になるのでしょうか?
with句…?values…?
valuesで、ない項目でテーブルを作る…?など色々調べたのですが、
結局一般的にどちらが使われるのでしょうか。。。

いつも足らずな質問となっていますが、
どなたか教えていただけると助かります。。。

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

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

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

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

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

guest

回答3

0

select x.商品ID, x.商品名, x.対象日, t.個数 from ( select a.商品ID, a.商品名, b.対象日 from ( select 商品ID, 商品名 from 商品テーブル group by 商品ID, 商品名 ) as a, values('2019-01-31','2019-02-28') as b(対象日) ) as x left join 商品テーブル as t on x.商品ID = t.商品ID and x.商品名 = t.商品名 and x.対象日 = t.対象日

とか? あくまで机上なので動作まで見てない。
(余計な引用符を削除しました。)

こういうことをやるとき、ちゃんと商品マスターテーブルと、商品ごとの個数管理用テーブルに
テーブル分割しないと効率が悪いですよ。

投稿2019/05/17 03:01

編集2019/05/17 04:29
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

sazi

2019/05/17 04:25 編集

>@m6uさん postgresは日本語のカラム名やテーブル名は"を使用せず使えますよ。 "を使用するのは逆に日本語では無くて、半角アルファベットの大文字・小文字を識別させたい時です。 とは言え、定義時に"を付加しちゃうと、ずっと付け続けないと駄目なのですが。
退会済みユーザー

退会済みユーザー

2019/05/17 04:27

なるほどそうでしたか。日本語とか使ったことがなくて経験の差が出てしまいましたね。
sazi

2019/05/17 08:33 編集

回答する時に意識されるのは、面倒だろうなと思ったので、お節介とは思いながらのコメントでした
xx_6_6_xx

2019/05/17 04:41

ご回答及び修正いただきありがとうございます。。。! もし今後私がテーブルを作成するようなことがあれば、 絶対に気を付けます。。。。
guest

0

ROW_NUMBER() で日付を降順にならべて欲しい件数だけ取得しては?

投稿2019/05/17 03:03

Orlofsky

総合スコア16415

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

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

0

ベストアンサー

色々やりかたはありますが、unnestを使用すると

SQL

1select t1.*, t2.個数 2from ( 3 SELECT 商品ID, 商品名 , unnest('{2019-01-31,2019-02-28}'::date[]) as 対象日 4 FROM 商品テーブル 5 group by 商品ID, 商品名 6 ) t1 7 left join 商品テーブル t2 8 on t1.商品ID=t2.商品ID and t1.対象日=t2.対象日

投稿2019/05/17 03:22

sazi

総合スコア25173

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

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

xx_6_6_xx

2019/05/17 04:40

いつもご回答いただきありがとうございます…! 思っていた結果が取得できました!! あと1つだけご教示ください。 これをストアドの中で使用します。。 実際は、unnest('{ }')の中にはdate1、date2という変数が入っています。。 それでもこのクエリは使用できますでしょうか?、、
sazi

2019/05/17 05:13

変数で使用するなら、 unnest(array[date1, date2]) の方が良いですね
xx_6_6_xx

2019/05/17 05:24

ありがとうございます!! 試したところ、完璧に結果が表示されました…!! 配列に格納しているイメージなのでしょうか…?
sazi

2019/05/17 05:29 編集

そうです。unnest()は配列を行に展開する関数です。 今回は規則のない日付でしたので、unnest()により展開しましたが、 一定間隔の連続した日付で展開するような場合は、generate_series()を知っておくと便利です。 9.24. 集合を返す関数(https://www.postgresql.jp/document/11/html/functions-srf.html)
xx_6_6_xx

2019/05/17 06:11

なるほど…!そういうこともできるのですね。。! またきっと同じようなクエリが必要になるので、覚えて使えるようにしておきます。 本当にありがとうございました。。。!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問