2025-11-21 15:57:18 +03:00
|
|
|
-- Миграция для добавления полей 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;
|
|
|
|
|
|
2025-11-24 13:36:14 +03:00
|
|
|
|