回答編集履歴

2

追加

2016/10/19 04:38

投稿

A.Ichi
A.Ichi

スコア4070

test CHANGED
@@ -122,4 +122,58 @@
122
122
 
123
123
 
124
124
 
125
+ SqlServerも作成しました。久々で自信はありませんが、動く様です。
125
126
 
127
+
128
+
129
+ ```
130
+
131
+ WITH EMP_CTE(id, jyoshi, buka)
132
+
133
+ AS
134
+
135
+ (
136
+
137
+ SELECT
138
+
139
+ id,
140
+
141
+ jyoshi,
142
+
143
+ buka
144
+
145
+ FROM
146
+
147
+ testAA
148
+
149
+ WHERE jyoshi = '上田一郎'
150
+
151
+
152
+
153
+ UNION ALL
154
+
155
+
156
+
157
+ SELECT
158
+
159
+ testAA.id,
160
+
161
+ testAA.jyoshi,
162
+
163
+ testAA.buka
164
+
165
+ FROM
166
+
167
+ testAA
168
+
169
+ INNER JOIN EMP_CTE
170
+
171
+ ON testAA.jyoshi = EMP_CTE.buka
172
+
173
+ )
174
+
175
+ --
176
+
177
+ DELETE FROM testAA WHERE id in (SELECT id FROM EMP_CTE);
178
+
179
+ ```

1

追加

2016/10/19 04:38

投稿

A.Ichi
A.Ichi

スコア4070

test CHANGED
@@ -69,3 +69,57 @@
69
69
  CALL sample03 ('上田一郎');
70
70
 
71
71
  ```
72
+
73
+
74
+
75
+
76
+
77
+ postgresでも作成してみました。指定された上司のレコードから、上司部下の関係のテーブルを最深階層(部下がいない)までを読み、そこから逆に上に戻りながら削除を行う動きとなります。
78
+
79
+
80
+
81
+ ```postgres
82
+
83
+ #ストアド
84
+
85
+ CREATE OR REPLACE FUNCTION test_sp_func9(in_name TEXT)
86
+
87
+ RETURNS INT AS $$
88
+
89
+
90
+
91
+ DECLARE rc tableA%rowtype;
92
+
93
+ DECLARE _ret int;
94
+
95
+ BEGIN
96
+
97
+
98
+
99
+ FOR rc IN SELECT * FROM tableA WHERE joshi=in_name LOOP
100
+
101
+ SELECT test_sp_func9 (rc.buka) INTO _ret;
102
+
103
+ DELETE FROM tableA WHERE joshi=rc.joshi AND buka=rc.buka;
104
+
105
+ END LOOP;
106
+
107
+ RETURN 0;
108
+
109
+
110
+
111
+ END;
112
+
113
+ $$ LANGUAGE plpgsql;
114
+
115
+
116
+
117
+ #実行
118
+
119
+ select test_sp_func9('上田一郎');
120
+
121
+ ```
122
+
123
+
124
+
125
+