-- Миграция для добавления полей unified_id, contact_id, phone в таблицу clpr_claims -- Дата: 2025-11-21 -- Описание: Добавляем поля для хранения идентификаторов пользователя напрямую в таблице заявок -- 1. Добавляем unified_id (уникальный идентификатор пользователя из CRM) ALTER TABLE clpr_claims ADD COLUMN IF NOT EXISTS unified_id TEXT; -- 2. Добавляем contact_id (ID контакта в RetailCRM) ALTER TABLE clpr_claims ADD COLUMN IF NOT EXISTS contact_id TEXT; -- 3. Добавляем phone (номер телефона пользователя) ALTER TABLE clpr_claims ADD COLUMN IF NOT EXISTS phone TEXT; -- 4. Создаём индексы для быстрого поиска CREATE INDEX IF NOT EXISTS idx_clpr_claims_unified_id ON clpr_claims(unified_id) WHERE unified_id IS NOT NULL; CREATE INDEX IF NOT EXISTS idx_clpr_claims_contact_id ON clpr_claims(contact_id) WHERE contact_id IS NOT NULL; CREATE INDEX IF NOT EXISTS idx_clpr_claims_phone ON clpr_claims(phone) WHERE phone IS NOT NULL; -- 5. Комментарии к полям COMMENT ON COLUMN clpr_claims.unified_id IS 'Уникальный идентификатор пользователя из CRM (формат: usr_xxx)'; COMMENT ON COLUMN clpr_claims.contact_id IS 'ID контакта в RetailCRM'; COMMENT ON COLUMN clpr_claims.phone IS 'Номер телефона пользователя (формат: 79262306381)'; -- 6. Опционально: заполняем существующие записи из payload (если есть) UPDATE clpr_claims SET unified_id = payload->>'unified_id', contact_id = payload->>'contact_id', phone = payload->>'phone' WHERE unified_id IS NULL AND ( payload->>'unified_id' IS NOT NULL OR payload->>'contact_id' IS NOT NULL OR payload->>'phone' IS NOT NULL ); -- Проверка результата SELECT COUNT(*) as total_claims, COUNT(unified_id) as with_unified_id, COUNT(contact_id) as with_contact_id, COUNT(phone) as with_phone FROM clpr_claims;