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

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

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

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

SQL

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

Treasure Data

Treasure Dataは、米国トレジャーデータ社の提供するクラウド型のデータマネジメントサービスです。ビッグデータ処理システムを備え、AWS上にセットアップされているため、データの集収、保管、分析を容易に行うことができます。

Q&A

解決済

1回答

4682閲覧

親IDをたくさん持つテーブルを、親ID(name)が左から順に並んでいるような表の形で抽出したい

9nom

総合スコア42

PostgreSQL

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

SQL

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

Treasure Data

Treasure Dataは、米国トレジャーデータ社の提供するクラウド型のデータマネジメントサービスです。ビッグデータ処理システムを備え、AWS上にセットアップされているため、データの集収、保管、分析を容易に行うことができます。

0グッド

0クリップ

投稿2017/10/05 23:23

親IDを持つこれらを、親のnameから順に左から並んでいるテーブルを作成したいです
より子供の方からleftjoinでparent_idを紐付けてくっつけていくと、親の階層が揃いません。
親の方から数えると、aとgは同じ階層になるはずですが、親をひたすらたどるクエリを書くと、階層数が異なるため、崩れた表になってしまいます。どのように書いたらいいでしょうか

idparent_idname
1nulla
23b
34c
41d
5nulle
67f
7nullg
86h
9nulli
10nullj

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

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

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

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

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

m.ts10806

2017/10/06 00:15

今現在組まれているSQLをご提示ください。また、親・子のテーブル定義とサンプルレコードがあればそれもあわせてお願いします。
guest

回答1

0

ベストアンサー

こういった自己結合によるツリー形式のテーブル(ナイーブツリー)にはwith recursiveによる再帰読出を使用すると、階層の深さなどを条件として意識する必要がありません。
但し、自己結合の関係(今回であれば、idとparent_id)がループするデータがあると無限ループします。
階層の深さで制限を掛けるなどしてデータの確認を行って下さい。
※サンプルでは階層のレベル(=lvl)も付加してあります。

データ

SQL

1drop table if exists list; 2create table list (id int, parent_id int, name text); 3insert into list values 4 (1,null,'a') 5,(2,3,'b') 6,(3,4,'c') 7,(4,1,'d') 8,(5,Null,'e') 9,(6,7,'f') 10,(7,null,'g') 11,(8,6,'h') 12,(9,null,'i') 13,(10,null,'j') 14;

問い合わせ(Postgres)

SQL

1with recursive tree as ( 2 select * 3 , 1 ::int as lvl 4 , array[name] as lvl_name 5 from list 6 where parent_id is null 7 union all 8 select list.* 9 , tree.lvl+1 10 , array_append(tree.lvl_name, list.name) 11 from list inner join tree on list.parent_id=tree.id 12) 13select id, parent_id, name 14 , lvl_name[1] as name1 15 , lvl_name[2] as name2 16 , lvl_name[3] as name3 17 , lvl_name[4] as name4 18from tree 19-- where lvl<=4 20order by lvl_name

追記 問い合わせ(Hive)

親を辿る方向で外部結合し、その状況から何階層目かを求めます(ここポイント)
その位置情報から取得すべき階層を判定し求めます。
※元データにこの何階層目かを判断できる情報があれば、その分簡潔になります。

SQL

1select id, parent_id, name 2 , case lvl when 4 then name_nest4 when 3 then name_nest3 when 2 then name_nest2 when 1 then name_nest1 end as name1 3 , case lvl when 4 then name_nest3 when 3 then name_nest2 when 2 then name_nest1 end as name2 4 , case lvl when 4 then name_nest2 when 3 then name_nest1 end as name3 5 , case lvl when 4 then name_nest1 end as name4 6from ( 7 select t1.* 8 , t1.name as name_nest1 9 , t2.name as name_nest2 10 , t3.name as name_nest3 11 , t4.name as name_nest4 12 , case when t4.id is not null then 4 13 else case when t3.id is not null then 3 14 else case when t2.id is not null then 2 else 1 end 15 end end as lvl 16 from list t1 left join list t2 on t2.id=t1.parent_id 17 left join list t3 on t3.id=t2.parent_id 18 left join list t4 on t4.id=t3.parent_id 19) step1

投稿2017/10/06 01:32

編集2017/10/06 09:10
sazi

総合スコア25206

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

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

9nom

2017/10/06 06:57

回答ありがとございます! Treasuredataを使っているのですが、(基本的にpostgresと同じですが)トレジャーデータではwith recursive treeがサポートされていないみたいでした、、、
sazi

2017/10/06 08:17 編集

追記しました。Hiveは扱ったことが無く、ネットの情報のみで記述しているのでエラーになるかもしれません。 並びは名前順でNulls First にしようとしましたが、可能かどうか分からなかったので、割愛。 階層はサンプルに合わせて4階層としているので、実際の階層数に合わせて下さい。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問