ホームページ > データベース > mysql チュートリアル > 異なる PostgreSQL データベース間でクエリを実行するにはどうすればよいですか?

異なる PostgreSQL データベース間でクエリを実行するにはどうすればよいですか?

Barbara Streisand
リリース: 2025-01-12 07:50:41
オリジナル
769 人が閲覧しました

How Can I Query Across Different PostgreSQL Databases?

PostgreSQL を使用してデータベース間でクエリを実行する

エラー メッセージが示すように、PostgreSQL 自体はクロスデータベース クエリをネイティブにサポートしていませんが、利用可能な回避策がいくつかあります。 1 つの方法は、postgres_fdw 拡張機能を使用することです。

postgres_fdw

postgres_fdw (外部データ ラッパー) を使用すると、場所に関係なく、PostgreSQL データベース内のテーブルに接続できます。この拡張機能を使用するには:

  1. Postgres のバージョンが postgres_fdw をサポートしていることを確認してください (v9.3 以降を推奨)。

  2. クロスデータベース クエリを実行する各データベースに postgres_fdw 拡張機能をインストールします。

  3. 外部サーバーとユーザーのマッピングを作成します:

    <code class="language-sql"> postgres=# CREATE SERVER foreign_server FOREIGN DATA WRAPPER postgres_fdw OPTIONS (host 'remote_host', port '5432');
     postgres=# CREATE USER MAPPING FOR CURRENT_USER SERVER foreign_server OPTIONS (user 'remote_user', password 'remote_password');</code>
    ログイン後にコピー
  4. 外部テーブルの作成:

    <code class="language-sql"> postgres=# CREATE FOREIGN TABLE cross_db_table SERVER foreign_server OPTIONS (table_name 'remote_table');</code>
    ログイン後にコピー

バージョン 9.3 より前の代替手段

9.3 より前の Postgres バージョンの場合、dblink という名前の関数を使用してデータベース間のクエリを実行できます。 PostgreSQL とともに保守・配布されていますが、postgres_fdw とは使用方法が異なります。 dblink の詳細については、PostgreSQL のドキュメントを参照してください。

以上が異なる PostgreSQL データベース間でクエリを実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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