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

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

新規登録して質問してみよう
ただいま回答率
85.50%
PL/SQL

PL/SQL (Procedural Language/Structured Query Language) はOracle CorporationによるSQL(非手続き型言語)を手続き型言語に拡張させるために開発されたプログラミング言語です。

Q&A

解決済

2回答

15587閲覧

PL/SQLでテーブルの存在チェックをする方法はないでしょうか?

退会済みユーザー

退会済みユーザー

総合スコア0

PL/SQL

PL/SQL (Procedural Language/Structured Query Language) はOracle CorporationによるSQL(非手続き型言語)を手続き型言語に拡張させるために開発されたプログラミング言語です。

0グッド

0クリップ

投稿2017/03/01 04:06

現在、テーブル名をループして、その値をもとに動的SQLでテーブルを作成するようプログラムを作成しております。ただ作成しようとしているテーブルの中には既に作成済みのテーブルもある為、その場合、それを飛ばすか、または作らない処理を作る必要があります。

その為、下記の変数「wk_sql」に値を入れる前にテーブルがある場合、continueで次の処理に進むか、または動的SQLの内容を「IF EXISTS」のような内容にしようと思っているのですが、PL/SQLの場合、どのように作成すればよろしいのでしょうか?

宜しくお願いいたします。

PL/SQL

1DECLARE 2 CURSOR cursor_emp IS 3 SELECT TABLE_NAME 4 FROM TT_TABLE; 5 6 record_emp cursor_emp%ROWTYPE; 7 8 wk_sql varchar2(1000); 9 10BEGIN 11 OPEN cursor_emp; 12 LOOP 13 FETCH cursor_emp INTO record_emp; 14 EXIT WHEN cursor_emp%NOTFOUND; 15 16 wk_sql := 'CREATE TABLE TEST_' || record_emp.TABLE_NAME || 17 ' as select * from ' || record_emp.TABLE_NAME || ' WHERE 1 = 0'; 18 19 EXECUTE IMMEDIATE wk_sql; 20 wk_sql := ''; 21 22 END LOOP; 23 CLOSE cursor_emp; 24 25END;

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

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

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

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

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

guest

回答2

0

select count(*) from user_tables where table_name = '{テーブル名}'などのクエリを発行し、IF文で結果が0の場合は存在しないとして処理すればいいです。

{テーブル名}および{スキーマ名}は探したいものを指定してください。

SQL

1-- ログインしているユーザーのスキーマにあるテーブルなら 2select table_name from user_tables where table_name = '{テーブル名}' 3-- 別のスキーマにあるテーブルなら 4select table_name from all_tables where table_name = '{テーブル名}' and owner='{スキーマ名}';

投稿2017/03/01 04:38

編集2017/03/01 04:41
Y.H.

総合スコア7914

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

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

0

ベストアンサー

データ・ディクショナリ・ビュー USER_TABLES を参照してください。

投稿2017/03/01 04:14

Orlofsky

総合スコア16415

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

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

退会済みユーザー

退会済みユーザー

2017/03/01 04:54

ありがとうございます。参照した結果、無事正常処理が出来ました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問