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

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

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

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

Q&A

1回答

2864閲覧

土日祝日の翌日を取り出すSQLを理解したいです。

dododo_pg

総合スコア21

PostgreSQL

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

0グッド

0クリップ

投稿2022/01/23 14:40

土日祝日の翌日を取り出すSQLの例文を見ていたのですが意味が分かりませんでした。
dualが日付を格納しているという設定を作るための仮のテーブルであることは理解できました。

以下ソースです。
(タイプミスあるかもなので実際の画像上げておきます。訳があって例文をコピペできませんでした。)

select holi2.* , to_char(sysdate + holi2.renban, 'yyyy/MM/dd') newDate ,case when to_char(sysdate + holi2.renban, 'yyyy/MM/dd') = holi2.ddate then 0 else 1 end chk from ( select holiday.ddate ,ROW_NUMBER() OVER (ORDER BY NULL) renban from ( select aaa.* from( select '2022/01/22' ddate from dual union all select '2022/01/23' ddate from dual union all select '2022/01/29' ddate from dual union all select '2022/01/30' ddate from dual union all select '2022/02/05' ddate from dual union all select '2022/02/06' ddate from dual union all select '2022/01/15' ddate from dual union all select '2022/01/16' ddate from dual ) aaa order by aaa.ddate )holiday where to_char(sysdate + 1, 'yyyy/MM/dd') <= holiday.ddate )holi2 )holi3 where holi3.chk = 1

疑問点を以下にあげます。

1.「2022/01/23」と「from」の間の「ddate」は何者か?
カンマで区切られていないなら列ではない。しかし列名とfromの間にddateなんて文字を入れることなんてできただろうか?

2.select区の「holiday.ddate」「aaa.*」、order by区の 「aaa.ddate」
いずれの区も「.」なんて入れることができただろうかという疑問です。
また、その意味を調べましたが分かりませんでした。
教えて欲しいです。

実際のSQL

SQLで営業日などを取り出すために是非覚えたいです。
よろしくお願いします。
どなたかよろしくお願いします。

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2022/01/24 02:08

FROM DUALって、Oracle Databaseの方言だった気がします。なにか、OracleのSQLの課題を、手元のPostgreSQL上で解決させようとしていたりしますか?
guest

回答1

0

ベストアンサー

1. 「2022/01/23」と「from」の間の「ddate」は何者か?

Synopsis

sql

1[ WITH [ RECURSIVE ] with_query [, ...] ] 2SELECT [ ALL | DISTINCT [ ON ( expression [, ...] ) ] ] 3 [ * | expression [ [ AS ] output_name ] [, ...] ]

https://www.postgresql.org/docs/current/sql-select.html

「ddate」はoutput_name(列の別名)のようですね。
ASが省略されているようです。

2. select区の「holiday.ddate」「aaa.*」、order by区の 「aaa.ddate」

4.2.1. Column References

A column can be referenced in the form:

correlation.columnname
correlation is the name of a table (possibly qualified with a schema name), or an alias for a table defined by means of a FROM clause. The correlation name and separating dot can be omitted if the column name is unique across all the tables being used in the current query. (See also Chapter 7.)
(機械翻訳)correlationは、テーブル名(スキーマ名で修飾されることもある)、またはFROM句によって定義されたテーブルの別名です。列名が現在の問い合わせで使用されている全てのテーブルで一意である場合、相関名と区切りドットは省略することができます。(第7章も参照してください)。
https://www.postgresql.org/docs/current/sql-expressions.html#SQL-EXPRESSIONS-COLUMN-REFS

列名の直前にある.の前の文字列はテーブル名(テーブルの別名)のようですね。

Examples
To join the table films with the table distributors:

sql

1SELECT f.title, f.did, d.name, f.date_prod, f.kind 2 FROM distributors d, films f 3 WHERE f.did = d.did 4 5 title | did | name | date_prod | kind 6-------------------+-----+--------------+------------+---------- 7 The Third Man | 101 | British Lion | 1949-12-23 | Drama 8 The African Queen | 101 | British Lion | 1951-08-11 | Romantic 9 ...

https://www.postgresql.org/docs/current/sql-select.html

複数のテーブルを参照する際に、列名が一意にならないこともありますので、どこのテーブルの列であるかを明示的に記述するのに使ったりします。
可読性のために省略可能であっても必ずつけることもあると思います。

投稿2022/01/24 04:52

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問