تخطي للذهاب إلى المحتوى
أودو القائمة
  • تسجيل الدخول
  • جرب مجاناً
  • التطبيقات
    المالية
    • المحاسبة
    • فوترة
    • النفقات
    • جدول البيانات (BI)
    • المستندات
    • توقيع إلكتروني
    المبيعات
    • إدارة علاقات العملاء
    • المبيعات
    • نقطة البيع للمتاجر
    • نقطة البيع للمطاعم
    • الاشتراكات
    • تأجير
    المواقع الإلكترونية
    • أداة بناء المواقع الإلكترونية
    • متاجر إلكترونية
    • مدونة
    • المنتدى
    • دردشة مباشرة
    • التعليم الإلكتروني
    سلسلة التوريد
    • المستودعات
    • التصنيع
    • إدارة دورة حياة المنتج
    • المشتريات
    • الصيانة
    • الجودة
    الموارد البشرية
    • موظفون
    • التوظيف
    • إجازة عمل
    • التقييمات
    • الإحالات
    • تطبيق الأسطول
    التسويق
    • التسويق الإجتماعي
    • التسويق عبر البريد الإلكتروني
    • التسويق عبر الرسائل النصية
    • فعاليات
    • أتمتة التسويق
    • الاستطلاعات
    الخدمات
    • المشاريع
    • الجداول الزمنية
    • الخدمة الميدانية
    • مكتب المساعدة
    • التخطيط
    • مواعيد
    اﻹنتاجية
    • مناقشة
    • الموافقات
    • إنترنت الأشياء "IoT"
    • بروتوكول ربط المحادثات الصوتية عبر الإنترنت
    • المعرفة
    • WhatsApp
    التطبيقات الخارجية ستوديو أودو منصة أودو السحابية
  • قطاعات الأعمال
    البيع بالتجزئة
    • متجر كتب
    • متجر ملابس
    • متجر أثاث
    • متجر بقالة
    • متجر معدات
    • متجر ألعاب
    الطعام والضيافة
    • بار وحانة
    • المطعم
    • مطعم للوجبات السريعة
    • نزل للضيوف
    • موزّع مشروبات
    • فندق
    العقارات
    • وكالة عقارات
    • شركة هندسة معمارية
    • البناء
    • إدارة العقارات
    • العناية بالحدائق
    • اتحاد مُلاّك العقارات
    استشارة
    • مؤسسة محاسبية
    • شريك أودو
    • وكالة تسويقية
    • منشأة قانونية
    • استقطاب المواهب
    • التدقيق والتوثيق
    التصنيع
    • الأقمشة
    • معدني
    • الأثاث
    • الطعام
    • مصنع خمور
    • هدايا الشركات
    الصحة واللياقة البدنية
    • نادي رياضي
    • متجر نظارات
    • مركز لياقة بدنية
    • الممارسون الصحيون
    • صيدلية
    • صالون تصفيف الشعر
    التجارة
    • عامل صيانة
    • الأجهزة والمعدات التقنية ودعمها
    • أنظمة الطاقة الشمسية
    • صانع أحذية
    • خدمات التنظيف
    • خدمات التكييف (HVAC)
    غير ذلك
    • منظمة غير ربحية
    • وكالة بيئية
    • تأجير لوحات إعلانية
    • تصوير
    • تأجير دراجات
    • بائع وسيط للبرمجيات
    تصفح كافة قطاعات الأعمال
  • مجتمع أودو
    تعلم
    • دروس
    • التوثيق
    • شهادات
    • التدريب
    • مدونة
    • بودكاست
    قم بتعزيز التعليم
    • برنامج تعليم
    • Scale UP! لعبة الأعمال
    • قم بزيارة أودو
    احصل على البرنامج
    • تحميل
    • قارنْ الإصدارات
    • إطلاق
    تعاون
    • جيت هاب "Github"
    • المنتدى
    • فعاليات
    • الترجمات
    • كنْ شريكاً
    • خدمات الشركاء
    • سجل مكتب المحاسبة الخاص بك
    احصل على الخدمات
    • اعثر على شريك
    • اعثر على محاسب
    • قابل أحد مرشدي الأعمال
    • خدمات التنفيذ
    • مراجع العملاء
    • الدعم
    • الترقيات
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    الحصول على عرض توضيحي
  • الأسعار
  • المساعدة

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • إدارة علاقات العملاء
  • e-Commerce
  • المحاسبة
  • المخزون
  • PoS
  • المشروع
  • MRP
All apps
يجب أن تكون مسجلاً حتى تتفاعل مع المجتمع.
كافة المنشورات الأفراد الشارات
علامات التصنيف (عرض الكل)
odoo accounting v14 pos v15
حول هذا المنتدى
يجب أن تكون مسجلاً حتى تتفاعل مع المجتمع.
كافة المنشورات الأفراد الشارات
علامات التصنيف (عرض الكل)
odoo accounting v14 pos v15
حول هذا المنتدى
المساعدة

How to resolve auto-increment ID conflicts during multi-master sync between two Odoo databases

اشتراك

تسلم الإشعارات عندما يكون هناك نشاط في هذا المنشور

لقد تم الإبلاغ عن هذا السؤال
issuessynchronizationsyncconflict
1 الرد
1147 أدوات العرض
الصورة الرمزية
Ali

Hello everyone,

I have two databases, one on a local server and the other on an external server. I want to implement a multi-master sync between them. Since Odoo uses auto-increment IDs, I’m concerned about potential ID conflicts during synchronization. How can I resolve the ID conflict issue in this scenario ?

0
الصورة الرمزية
إهمال
الصورة الرمزية
Cybrosys Techno Solutions Pvt.Ltd
أفضل إجابة

Hi,

To avoid ID conflicts between your two Odoo databases during synchronization, we’ve configured each server to use a different number range for all auto-incrementing sequences.

  • Server 1 (Local): generates only odd numbers (1, 3, 5, ...)

  • Server 2 (External): generates only even numbers (2, 4, 6, ...)

This ensures both systems can safely create new records without any ID collisions.

To apply this, please follow these steps:

  1. Connect to PostgreSQL and select your Odoo database:

psql -U your_pg_user -d your_odoo_database

(Replace your_pg_user and your_odoo_database with the actual PostgreSQL username and database name.)

  1. Then run the following script on each server:

-> On Server 1 (Odd IDs):

DO $$

DECLARE

    seq_name TEXT;

BEGIN

    FOR seq_name IN

        SELECT sequence_name

        FROM information_schema.sequences

        WHERE sequence_schema = 'public'

    LOOP

        EXECUTE format('ALTER SEQUENCE %I RESTART WITH 1 INCREMENT BY 2', seq_name);

    END LOOP;

END $$;

-> On Server 2 (Even IDs):

DO $$

DECLARE

    seq_name TEXT;

BEGIN

    FOR seq_name IN

        SELECT sequence_name

        FROM information_schema.sequences

        WHERE sequence_schema = 'public'

    LOOP

        EXECUTE format('ALTER SEQUENCE %I RESTART WITH 2 INCREMENT BY 2', seq_name);

    END LOOP;

END $$;

After applying this setup, both databases will generate unique IDs automatically, preventing any conflicts during syncing.

OR

If your databases already contain data, we need to make sure new IDs start after the highest existing ID in each table.

This ensures:

  • No overlapping IDs during sync

  • Continuity of your existing data without conflict or duplication

Connect to your databases and run the following query:

-> For Server 1 (Odd numbers — local server):

DO $$

DECLARE

    seq_name TEXT;

    tbl_name TEXT;

    col_name TEXT := 'id';

    max_id BIGINT;

    col_exists BOOLEAN;

BEGIN

    FOR seq_name IN

        SELECT sequence_name

        FROM information_schema.sequences

        WHERE sequence_schema = 'public'

    LOOP

        tbl_name := replace(seq_name, '_id_seq', '');


        -- Check if the table has an 'id' column

        SELECT EXISTS (

            SELECT 1

            FROM information_schema.columns

            WHERE table_schema = 'public'

              AND table_name = tbl_name

              AND column_name = col_name

        ) INTO col_exists;


        IF col_exists THEN

            BEGIN

                EXECUTE format('SELECT MAX(%I) FROM %I', col_name, tbl_name) INTO max_id;

                IF max_id IS NULL THEN

                    max_id := 0;

                END IF;

                -- Set starting point to next available odd number

                IF (max_id + 1) % 2 = 0 THEN

                    max_id := max_id + 2;

                ELSE

                    max_id := max_id + 1;

                END IF;

                EXECUTE format('ALTER SEQUENCE %I RESTART WITH %s INCREMENT BY 2', seq_name, max_id);

            EXCEPTION WHEN OTHERS THEN

                RAISE NOTICE 'Skipped sequence % due to table error', seq_name;

            END;

        ELSE

            RAISE NOTICE 'Skipped sequence % (no "id" column in table %)', seq_name, tbl_name;

        END IF;

    END LOOP;

END $$;

-> For Server 2 (Even numbers — external server):

In the above script, simply adjust the logic to start with the next even number instead.


Hope it helps.

0
الصورة الرمزية
إهمال
هل أعجبك النقاش؟ لا تكن مستمعاً فقط. شاركنا!

أنشئ حساباً اليوم لتستمتع بالخصائص الحصرية، وتفاعل مع مجتمعنا الرائع!

تسجيل
المنشورات ذات الصلة الردود أدوات العرض النشاط
Sync of 2 Odoo's ?
security synchronization sync
الصورة الرمزية
0
يناير 21
3630
Bank synchronization nothing happens
bank_statement bank synchronization sync
الصورة الرمزية
الصورة الرمزية
1
فبراير 25
2853
TD Ameritrade Account Sync to Odoo accounting
synchronization syncronisation sync broker
الصورة الرمزية
0
أغسطس 23
2148
Odoo mobile fields sync problem تم الحل
mobile synchronization sync framework
الصورة الرمزية
1
يونيو 17
4881
How To Synchronize Localhost Database to online Server Database In odoo pos
synchronization
الصورة الرمزية
الصورة الرمزية
الصورة الرمزية
2
أكتوبر 25
5913
المجتمع
  • دروس
  • التوثيق
  • المنتدى
مصدر مفتوح
  • تحميل
  • جيت هاب "Github"
  • المشغل الآلي رنبوت
  • الترجمات
خدماتنا
  • استضافة أودو إس إتش
  • الدعم
  • الترقية
  • التطويرات المخصصة
  • التعليم
  • اعثر على محاسب
  • اعثر على شريك
  • كنْ شريكاً
معلومات عنا
  • شركتنا
  • أصول العلامة التجارية
  • اتصلْ بنا
  • الوظائف
  • فعاليات
  • بودكاست
  • مدونة
  • عملاء
  • قانوني • الخصوصية
  • الحماية
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

أودو هو عبارة عن مجموعة من تطبيقات الأعمال مفتوحة المصدر التي تغطي جميع احتياجات شركتك، مثل: إدارة علاقات العملاء والتجارة الإلكترونية والمحاسبة والمخزون ونقاط البيع وإدارة المشاريع وما إلى ذلك.

ما يجعل من أودو مميزاً هو هدفه بأن يكون سهل الاستخدام للغاية ومتكاملاً تمامًا في الوقت ذاته.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now