فشل ترحيل قاعدة البيانات بالإصدار 20210714173022 عند تخطي ترحيلات ما بعد النشر السابقة

حدث التحديث إلى النسخة المستقرة (v2.7.8) في الحاوية الأولى مع تفعيل خيار SKIP_POST_DEPLOYMENT_MIGRATIONS.
عند تشغيله مرة ثانية في الحاوية الأخرى مع تعطيل خيار التخطي، فشلت مهمة الترحيل CorrectlyMoveAssignmentsFromCustomFieldsToATable:

PG::NotNullViolation: ERROR:  null value in column "assigned_to_type"
of relation "assignments" violates not-null constraint

بحسب ما أستطيع رؤيته، لا ينبغي تنفيذ مهمة الترقية AddAssignedToTypeToAssignments (التي تنشئ قيد عدم السماح بالقيم الفارغة) حتى تنتهي مهمة CorrectlyMoveAssignmentsFromCustomFieldsToATable.

كحل بديل، قمت بما يلي:

INSERT INTO assignments
(assigned_to_id, assigned_by_user_id, topic_id, created_at, updated_at,assigned_to_type)
SELECT
  assigned_to.value::integer,
  assigned_by.value::integer,
  assigned_by.topic_id,
  assigned_by.created_at,
  assigned_by.updated_at,
  'User'
FROM topic_custom_fields assigned_by
INNER JOIN topic_custom_fields assigned_to
ON assigned_to.topic_id = assigned_by.topic_id
WHERE assigned_by.name = 'assigned_by_id'
AND assigned_to.name = 'assigned_to_id'
ORDER BY assigned_by.created_at DESC
ON CONFLICT DO NOTHING;

INSERT INTO schema_migration_details
(version,
name,
hostname,
git_version,
rails_version,
duration,
direction,
created_at)
values(
'20210714173022',
'CorrectlyMoveAssignmentsFromCustomFieldsToATable',
'ce4fb45daf62',
'98b0621d538fa4e8a53e1e74127c24c384be9b58',
'6.1.3.2',
0,
'up',
'2021-09-28 15:20:00.123456'
);

INSERT INTO schema_migrations values('20210714173022');

بعد ذلك، تمكنت من إعادة بناء الحاوية.

إعجابَين (2)

شكرًا لك على التحقيق، قمنا بإصلاح عملية الهجرة عبر طلب السحب:

3 إعجابات

كان ذلك سريعًا. شكرًا لك :slight_smile:

إعجابَين (2)