mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-14 19:45:11 +00:00
c09fa0b843
Spelling
1.5 KiB
1.5 KiB
toc_priority | toc_title |
---|---|
12 | MaterializedPostgreSQL |
MaterializedPostgreSQL
Creating a Table
CREATE TABLE test.postgresql_replica (key UInt64, value UInt64)
ENGINE = MaterializedPostgreSQL('postgres1:5432', 'postgres_database', 'postgresql_replica', 'postgres_user', 'postgres_password')
PRIMARY KEY key;
Requirements
-
Setting
wal_level
tological
andmax_replication_slots
to at least2
in the postgresql config file. -
A table with engine
MaterializedPostgreSQL
must have a primary key - the same as a replica identity index (default: primary key) of a postgres table (See details on replica identity index). -
Only database
Atomic
is allowed.
Virtual columns
-
_version
(UInt64
) -
_sign
(Int8
)
These columns do not need to be added, when table is created. They are always accessible in SELECT
query.
_version
column equals LSN
position in WAL
, so it might be used to check how up-to-date replication is.
CREATE TABLE test.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 test.postgresql_replica;
Warning
- TOAST values convertion is not supported. Default value for the data type will be used.