ホームページ > データベース > mysql チュートリアル > 「IF NOT EXISTS」を使用して PostgreSQL でテーブルを作成する方法?

「IF NOT EXISTS」を使用して PostgreSQL でテーブルを作成する方法?

Barbara Streisand
リリース: 2025-01-04 09:43:40
オリジナル
391 人が閲覧しました

How to Create Tables in PostgreSQL Using

PostgreSQL の「IF NOT EXISTS」句を使用してテーブルを作成する方法

MySQL では、ユーザーが「IF NOT EXISTS」句を使用してテーブルを作成できるようにします、テーブルがまだ存在しない場合にのみ作成されるようにします。これにより、スクリプトが複数回実行される場合のエラーが防止されます。

PostgreSQL では、この機能はバージョン 9.1 で導入され、以下の使用が可能になりました。

CREATE TABLE IF NOT EXISTS myschema.mytable (i integer);
ログイン後にコピー

PostgreSQL の以前のバージョンでは、次のものが使用できます。回避策として関数を使用できます:

CREATE OR REPLACE FUNCTION create_mytable()
  RETURNS void
  LANGUAGE plpgsql AS
$func$
BEGIN
   IF EXISTS (SELECT FROM pg_catalog.pg_tables 
              WHERE  schemaname = 'myschema'
              AND    tablename  = 'mytable') THEN
      RAISE NOTICE 'Table myschema.mytable already exists.';
   ELSE
      CREATE TABLE myschema.mytable (i integer);
   END IF;
END
$func$;
ログイン後にコピー

この関数は必要に応じて何度でも呼び出すことができますusing:

SELECT create_mytable();
ログイン後にコピー

注:

  • pg_tables のスキーマ名とテーブル名の列は大文字と小文字が区別されます。
  • pg_tables には実際のスキーマ名のみが含まれますテーブルのため、識別子は関連するテーブルによって占有されている可能性があります。オブジェクト。
  • 関数を実行するユーザーがテーブルの作成に必要な権限を持っていない場合、SECURITY DEFINER 属性を関数に使用できます。

以上が「IF NOT EXISTS」を使用して PostgreSQL でテーブルを作成する方法?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート