> ## Documentation Index
> Fetch the complete documentation index at: https://private-7c7dfe99-mintlify-8a08bda2.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

> PostgreSQL テーブルの初期データダンプを含む ClickHouse テーブルを作成し、レプリケーションを開始します。

# MaterializedPostgreSQL テーブルエンジン

export const CloudNotSupportedBadge = () => {
  return <div className="cloudNotSupportedBadge">
            <div className="cloudNotSupportedIcon">
            <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
                <path strokeWidth="1.5" d="M6.33366 12.6666L12.3739 12.6667C13.6593 12.6667 14.7073 11.6187 14.7073 10.3334C14.7073 9.04804 13.6593 8.00003 12.3739 8.00003C12.3739 8.00003 12.3337 7.66659 12.0003 7.33325M10.667 5.33322C8.00033 2.33325 4.45395 4.78537 4.14195 6.68203C2.55728 6.7627 1.29395 8.06203 1.29395 9.6667C1.29395 11.3234 2.66699 12.6666 4.00033 12.6666" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
                <path strokeWidth="1.5" d="M2.66699 14L12.0003 4.66663" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
            </svg>

        </div>
            Not supported in ClickHouse Cloud
        </div>;
};

export const ExperimentalBadge = () => {
  return <div className="experimentalBadge">
            <div className="experimentalIcon">
            <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
                <path strokeWidth="1.25" d="M5.5 2H10.5" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
                <path strokeWidth="1.25" d="M9.50015 2V6.19625L13.4283 12.7425C13.4738 12.8183 13.4985 12.9049 13.4996 12.9934C13.5008 13.0818 13.4785 13.169 13.435 13.246C13.3914 13.323 13.3283 13.3871 13.2519 13.4317C13.1755 13.4764 13.0886 13.4999 13.0002 13.5H3.00015C2.91164 13.5 2.8247 13.4766 2.74822 13.432C2.67174 13.3874 2.60847 13.3233 2.56487 13.2463C2.52126 13.1693 2.49889 13.082 2.50004 12.9935C2.50119 12.905 2.52582 12.8184 2.5714 12.7425L6.50015 6.19625V2" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
                <path strokeWidth="1.25" d="M4.47656 9.56754C5.30344 9.41254 6.47656 9.47942 7.99969 10.25C10.0153 11.2707 11.4216 11.0569 12.2184 10.7282" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
            </svg>
        </div>
            Experimental feature. <u><a href="/docs/beta-and-experimental-features#experimental-features">Learn more.</a></u>
        </div>;
};

<Note>
  ClickHouse Cloud ユーザーには、PostgreSQL から ClickHouse へのレプリケーションには [ClickPipes](/ja/integrations/clickpipes/home) の使用を推奨します。これは、PostgreSQL 向けの高性能な CDC (変更データキャプチャ) をネイティブにサポートしています。
</Note>

PostgreSQL テーブルの初期データダンプを基に ClickHouse テーブルを作成し、レプリケーションプロセスを開始します。つまり、リモート PostgreSQL データベース内の PostgreSQL テーブルで新しい変更が発生すると、それを適用するバックグラウンドジョブを実行します。

<Note>
  このテーブルエンジンは実験的機能です。使用するには、設定ファイルで `allow_experimental_materialized_postgresql_table` を 1 に設定するか、`SET` コマンドを使用してください。

  ```sql theme={null}
  SET allow_experimental_materialized_postgresql_table=1
  ```
</Note>

複数のテーブルが必要な場合は、テーブルエンジンではなく [MaterializedPostgreSQL](/ja/reference/engines/database-engines/materialized-postgresql) データベースエンジンを使用し、レプリケートするテーブルを指定する `materialized_postgresql_tables_list` 設定を使用することを強く推奨します (今後はデータベース `schema` の追加も可能になる予定です) 。その方が、CPU 使用量、接続数、リモート PostgreSQL データベース内のレプリケーションスロット数の面で大幅に効率的です。

<div id="creating-a-table">
  ## テーブルの作成
</div>

```sql theme={null}
CREATE TABLE postgresql_db.postgresql_replica (key UInt64, value UInt64)
ENGINE = MaterializedPostgreSQL('postgres1:5432', 'postgres_database', 'postgresql_table', 'postgres_user', 'postgres_password')
PRIMARY KEY key;
```

**エンジンパラメータ**

* `host:port` — PostgreSQLサーバーのアドレス。
* `database` — リモートデータベース名。
* `table` — リモートテーブル名。
* `user` — PostgreSQLユーザー。
* `password` — ユーザーのパスワード。

<div id="requirements">
  ## 要件
</div>

1. PostgreSQL の設定ファイルで、[wal\_level](https://www.postgresql.org/docs/current/runtime-config-wal.html) の値を `logical` に設定し、`max_replication_slots` パラメータの値を少なくとも `2` に設定する必要があります。

2. `MaterializedPostgreSQL` エンジンを使用するテーブルには、PostgreSQL テーブルの replica identity index (デフォルトでは主キー) と同じ主キーが必要です ([replica identity index の詳細](/ja/reference/engines/database-engines/materialized-postgresql#requirements)を参照) 。

3. 使用できるのは [Atomic](https://en.wikipedia.org/wiki/Atomicity_\(database_systems\)) データベースのみです。

4. `MaterializedPostgreSQL` テーブルエンジンは、実装上 PostgreSQL の [pg\_replication\_slot\_advance](https://pgpedia.info/p/pg_replication_slot_advance.html) 関数を必要とするため、PostgreSQL バージョン 11 以上でのみ動作します。

<div id="virtual-columns">
  ## 仮想カラム
</div>

* `_version` — トランザクションカウンター。Type: [UInt64](/ja/reference/data-types/int-uint)。

* `_sign` — 削除マーク。Type: [Int8](/ja/reference/data-types/int-uint)。設定可能な値:
  * `1` — 行は削除されていません。
  * `-1` — 行は削除されています。

これらのカラムは、テーブル作成時に追加する必要はありません。`SELECT` クエリから常に参照できます。
`_version` カラムは `WAL` 内の `LSN` の位置に対応するため、レプリケーションがどの程度最新かを確認する際に使用できます。

```sql theme={null}
CREATE TABLE postgresql_db.postgresql_replica (key UInt64, value UInt64)
ENGINE = MaterializedPostgreSQL('postgres1:5432', 'postgres_database', 'postgresql_replica', 'postgres_user', 'postgres_password')
PRIMARY KEY key;

SELECT key, value, _version FROM postgresql_db.postgresql_replica;
```

<Note>
  [**TOAST**](https://www.postgresql.org/docs/9.5/storage-toast.html) の値のレプリケーションには対応していません。代わりに、データ型のデフォルト値が使用されます。
</Note>
