6.7 KiB
slug | sidebar_position | sidebar_label |
---|---|---|
/ja/sql-reference/table-functions/postgresql | 160 | postgresql |
postgresql
リモートのPostgreSQLサーバーに保存されているデータに対してSELECT
およびINSERT
クエリを実行することができます。
構文
postgresql({host:port, database, table, user, password[, schema, [, on_conflict]] | named_collection[, option=value [,..]]})
パラメータ
host:port
— PostgreSQLサーバーのアドレス。database
— リモートデータベース名。table
— リモートテーブル名。user
— PostgreSQLユーザー。password
— ユーザーパスワード。schema
— デフォルトでないテーブルスキーマ。オプション。on_conflict
— コンフリクト解決戦略。例:ON CONFLICT DO NOTHING
。オプション。
引数は名前付きコレクションを使用して渡すこともできます。この場合、host
とport
は別々に指定する必要があります。この方法は本番環境に推奨されます。
返される値
元のPostgreSQLテーブルと同じカラムを持つテーブルオブジェクト。
:::note
テーブル関数postgresql(...)
をテーブル名とカラム名リストから区別するために、INSERT
クエリではキーワードFUNCTION
またはTABLE FUNCTION
を使用しなければなりません。以下の例をご覧ください。
:::
実装の詳細
PostgreSQL側でのSELECT
クエリは、読み取り専用PostgreSQLトランザクション内でCOPY (SELECT ...) TO STDOUT
として実行され、各SELECT
クエリ後にコミットされます。
=
, !=
, >
, >=
, <
, <=
, およびIN
などの単純なWHERE
句はPostgreSQLサーバーで実行されます。
すべてのジョイン、集計、ソート、IN [ array ]
条件、およびLIMIT
サンプリング制約は、PostgreSQLへのクエリ終了後にClickHouseのみで実行されます。
PostgreSQL側でのINSERT
クエリは、PostgreSQLトランザクション内で自動コミットで各INSERT
文後にCOPY "table_name" (field1, field2, ... fieldN) FROM STDIN
として実行されます。
PostgreSQL配列型はClickHouseの配列に変換されます。
:::note 注意が必要です。PostgreSQLでは、データ型カラムが異なる次元の配列を含むことができるが、ClickHouseではすべての行で同じ次元の多次元配列のみが許可されます。 :::
複数のレプリカをサポートし、|
でリストする必要があります。例えば:
SELECT name FROM postgresql(`postgres{1|2|3}:5432`, 'postgres_database', 'postgres_table', 'user', 'password');
または
SELECT name FROM postgresql(`postgres1:5431|postgres2:5432`, 'postgres_database', 'postgres_table', 'user', 'password');
PostgreSQL Dictionaryソースのレプリカ優先度をサポートします。マップ内の数字が大きいほど優先度が低くなります。最も高い優先度は0
です。
例
PostgreSQLのテーブル:
postgres=# CREATE TABLE "public"."test" (
"int_id" SERIAL,
"int_nullable" INT NULL DEFAULT NULL,
"float" FLOAT NOT NULL,
"str" VARCHAR(100) NOT NULL DEFAULT '',
"float_nullable" FLOAT NULL DEFAULT NULL,
PRIMARY KEY (int_id));
CREATE TABLE
postgres=# INSERT INTO test (int_id, str, "float") VALUES (1,'test',2);
INSERT 0 1
postgresql> SELECT * FROM test;
int_id | int_nullable | float | str | float_nullable
--------+--------------+-------+------+----------------
1 | | 2 | test |
(1 row)
ClickHouseからのデータ選択(プレーン引数使用):
SELECT * FROM postgresql('localhost:5432', 'test', 'test', 'postgresql_user', 'password') WHERE str IN ('test');
または名前付きコレクションを使用:
CREATE NAMED COLLECTION mypg AS
host = 'localhost',
port = 5432,
database = 'test',
user = 'postgresql_user',
password = 'password';
SELECT * FROM postgresql(mypg, table='test') WHERE str IN ('test');
┌─int_id─┬─int_nullable─┬─float─┬─str──┬─float_nullable─┐
│ 1 │ ᴺᵁᴸᴸ │ 2 │ test │ ᴺᵁᴸᴸ │
└────────┴──────────────┴───────┴──────┴────────────────┘
挿入:
INSERT INTO TABLE FUNCTION postgresql('localhost:5432', 'test', 'test', 'postgrsql_user', 'password') (int_id, float) VALUES (2, 3);
SELECT * FROM postgresql('localhost:5432', 'test', 'test', 'postgresql_user', 'password');
┌─int_id─┬─int_nullable─┬─float─┬─str──┬─float_nullable─┐
│ 1 │ ᴺᵁᴸᴸ │ 2 │ test │ ᴺᵁᴸᴸ │
│ 2 │ ᴺᵁᴸᴸ │ 3 │ │ ᴺᵁᴸᴸ │
└────────┴──────────────┴───────┴──────┴────────────────┘
デフォルトでないスキーマの使用:
postgres=# CREATE SCHEMA "nice.schema";
postgres=# CREATE TABLE "nice.schema"."nice.table" (a integer);
postgres=# INSERT INTO "nice.schema"."nice.table" SELECT i FROM generate_series(0, 99) as t(i)
CREATE TABLE pg_table_schema_with_dots (a UInt32)
ENGINE PostgreSQL('localhost:5432', 'clickhouse', 'nice.table', 'postgrsql_user', 'password', 'nice.schema');
関連項目
関連コンテンツ
PeerDBを用いたPostgresデータのレプリケーションまたは移行
テーブル関数に加えて、PeerDBを使用してPostgresからClickHouseへの継続的なデータパイプラインを設定することもできます。PeerDBは、変更データキャプチャ(CDC)を使用してPostgresからClickHouseにデータをレプリケートするために設計されたツールです。