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

> ينشئ جدول ClickHouse باستخدام تفريغ بيانات أولي لجدول PostgreSQL ويبدأ عملية النسخ المتماثل.

# محرك الجدول 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>
            غير مدعوم في 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>
            ميزة تجريبية. <u><a href="/docs/beta-and-experimental-features#experimental-features">تعرّف على المزيد.</a></u>
        </div>;
};

<Note>
  يُنصح مستخدمو ClickHouse Cloud باستخدام [ClickPipes](/ar/integrations/clickpipes/home) لنسخ البيانات من PostgreSQL إلى ClickHouse. يوفّر هذا دعمًا أصيلاً وعالي الأداء لتقنية Change Data Capture (CDC) في PostgreSQL.
</Note>

ينشئ جدولًا في ClickHouse من خلال تفريغٍ أولي لبيانات جدول PostgreSQL، ثم يبدأ عملية النسخ المتماثل. أي إنه ينفّذ مهمةً في الخلفية لتطبيق التغييرات الجديدة فور حدوثها على جدول PostgreSQL في قاعدة بيانات PostgreSQL البعيدة.

<Note>
  محرك الجدول هذا تجريبي. لاستخدامه، اضبط `allow_experimental_materialized_postgresql_table` على 1 في ملفات الإعدادات لديك أو باستخدام الأمر `SET`:

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

إذا كانت هناك حاجة إلى أكثر من جدول واحد، فمن المستحسن بشدة استخدام محرك قاعدة البيانات [MaterializedPostgreSQL](/ar/reference/engines/database-engines/materialized-postgresql) بدلًا من محرك الجدول، واستخدام الإعداد `materialized_postgresql_tables_list` الذي يحدّد الجداول المطلوب نسخها متماثلًا (وسيصبح من الممكن أيضًا إضافة `schema` قاعدة البيانات). وسيكون ذلك أفضل بكثير من حيث استهلاك CPU، وتقليل عدد الاتصالات، وتقليل عدد replication slots داخل قاعدة بيانات 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. يجب أن تكون قيمة الإعداد [wal\_level](https://www.postgresql.org/docs/current/runtime-config-wal.html) هي `logical`، كما يجب أن تكون قيمة المعامل `max_replication_slots` `2` على الأقل في ملف إعدادات PostgreSQL.

2. يجب أن يحتوي الجدول ذو محرك `MaterializedPostgreSQL` على مفتاح أساسي يطابق فهرس هوية النسخة المتماثلة (replica identity) لجدول PostgreSQL (افتراضيًا: المفتاح الأساسي) (راجع [التفاصيل حول فهرس هوية النسخة المتماثلة](/ar/reference/engines/database-engines/materialized-postgresql#requirements)).

3. يُسمح فقط بقاعدة بيانات [Atomic](https://en.wikipedia.org/wiki/Atomicity_\(database_systems\)).

4. لا يعمل محرك الجدول `MaterializedPostgreSQL` إلا مع إصدارات PostgreSQL >= 11، لأن التنفيذ يتطلب دالة PostgreSQL ‏[pg\_replication\_slot\_advance](https://pgpedia.info/p/pg_replication_slot_advance.html).

<div id="virtual-columns">
  ## الأعمدة الافتراضية
</div>

* `_version` — عدّاد المعاملات. النوع: [UInt64](/ar/reference/data-types/int-uint).

* `_sign` — علامة الحذف. النوع: [Int8](/ar/reference/data-types/int-uint). القيم الممكنة:
  * `1` — الصف غير محذوف،
  * `-1` — الصف محذوف.

لا حاجة إلى إضافة هذه الأعمدة عند إنشاء جدول. وهي متاحة دائمًا في استعلام `SELECT`.
تعادل قيمة العمود `_version` موضع `LSN` في `WAL`، لذلك يمكن استخدامه للتحقق من مدى حداثة النسخ المتماثل.

```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>
