| ページ一覧 | ブログ | twitter |  書式 | 書式(表) |

MyMemoWiki

「DB2 再帰で区切りリストを作成」の版間の差分

提供: MyMemoWiki
ナビゲーションに移動 検索に移動
1行目: 1行目:
==DB2 再帰で区切りリストを作成==
+
==[[DB2 再帰で区切りリストを作成]]==
[[DB2]] | [[Database]] | {{category SQL}}[[DB2 再帰]] |  
+
[[DB2]] | [[Database]] | [[Category:SQL]][[DB2 再帰]] |  
  
 
{{amazon|4873113156}}
 
{{amazon|4873113156}}
7行目: 7行目:
 
*UNION ALLの上側は、各従業員に対する情報を返す
 
*UNION ALLの上側は、各従業員に対する情報を返す
 
*UNION ALLの下側で再帰が発生
 
*UNION ALLの下側で再帰が発生
*WITH句内のWHERE 句で再帰条件を指定
+
*WITH句内のWHE[[R]]E 句で再帰条件を指定
 
*x.len+1 は評価された従業員数、部署の人数と比較し必要以上の再帰を抑制
 
*x.len+1 は評価された従業員数、部署の人数と比較し必要以上の再帰を抑制
 
   
 
   
25行目: 25行目:
  
 
=====結果=====
 
=====結果=====
  WORKDEPT   LIST
+
  WO[[R]]KDEPT   LIST
 
  --------  -------------------------------------------------------------------------------------------------
 
  --------  -------------------------------------------------------------------------------------------------
  A00      HAAS , LUCCHESSI , O'CONNELL , HEMMINGER , ORLANDO
+
  A00      HAAS , LUCCHESSI , O'CONNELL , HEMMINGE[[R]] , O[[R]]LANDO
 
  B01      THOMPSON
 
  B01      THOMPSON
 
  C01      KWAN , QUINTANA , NICHOLLS , NATZ
 
  C01      KWAN , QUINTANA , NICHOLLS , NATZ
  D11      STERN , ADAMSON , PIANKA , YOSHIMURA , SCOUTTEN , WALKER , BROWN , JONES , LUTZ , YAMAMOTO , JOHN
+
  D11      STE[[R]]N , ADAMSON , PIANKA , YOSHIMU[[R]]A , SCOUTTEN , WALKE[[R]] , B[[R]]OWN , JONES , LUTZ , YAMAMOTO , JOHN
  D21      PULASKI , JEFFERSON , MARINO , SMITH , JOHNSON , PEREZ , MONTEVERDE
+
  D21      PULASKI , JEFFE[[R]]SON , MA[[R]]INO , SMITH , JOHNSON , PE[[R]]EZ , MONTEVE[[R]]DE
  E01      GEYER
+
  E01      GEYE[[R]]
  E11      HENDERSON , SCHNEIDER , PARKER , SMITH , SETRIGHT , SCHWARTZ , SPRINGER
+
  E11      HENDE[[R]]SON , SCHNEIDE[[R]] , PA[[R]]KE[[R]] , SMITH , SET[[R]]IGHT , SCHWA[[R]]TZ , SP[[R]]INGE[[R]]
  E21      SPENSER , MEHTA , LEE , GOUNOT , WONG , ALONZO
+
  E21      SPENSE[[R]] , MEHTA , LEE , GOUNOT , WONG , ALONZO

2020年2月16日 (日) 04:23時点における版

DB2 再帰で区切りリストを作成

DB2 | Database |DB2 再帰 |

  • WITH句を使った再帰的なクエリで実現
  • UNION ALLの上側は、各従業員に対する情報を返す
  • UNION ALLの下側で再帰が発生
  • WITH句内のWHERE 句で再帰条件を指定
  • x.len+1 は評価された従業員数、部署の人数と比較し必要以上の再帰を抑制
with x (workdept, cnt, list, empno, len) as (
    select workdept, count(*) over(partition by workdept), cast(lastname as varchar(200)),empno,1
    from employee
    union all
    select x.workdept,x.cnt, x.list || ' , ' || e.lastname, e.empno, x.len+1
    from employee e, x
    where e.workdept = x.workdept
    and e.empno > x.empno
)
select workdept, list 
from x
where len = cnt
order by workdept
結果
WORKDEPT   LIST
--------   -------------------------------------------------------------------------------------------------
A00       HAAS , LUCCHESSI , O'CONNELL , HEMMINGER , ORLANDO
B01       THOMPSON
C01       KWAN , QUINTANA , NICHOLLS , NATZ
D11       STERN , ADAMSON , PIANKA , YOSHIMURA , SCOUTTEN , WALKER , BROWN , JONES , LUTZ , YAMAMOTO , JOHN
D21       PULASKI , JEFFERSON , MARINO , SMITH , JOHNSON , PEREZ , MONTEVERDE
E01       GEYER
E11       HENDERSON , SCHNEIDER , PARKER , SMITH , SETRIGHT , SCHWARTZ , SPRINGER
E21       SPENSER , MEHTA , LEE , GOUNOT , WONG , ALONZO