diff --git a/db-migrations/20260215_fix_duplicate_assigned_dispatches.sql b/db-migrations/20260215_fix_duplicate_assigned_dispatches.sql index a4c1b96..21d2d1d 100644 --- a/db-migrations/20260215_fix_duplicate_assigned_dispatches.sql +++ b/db-migrations/20260215_fix_duplicate_assigned_dispatches.sql @@ -123,7 +123,7 @@ BEGIN AND d.status = 'ASSIGNED' AND d.active = true WHERE t.dispatch_status = 'DISPATCH' - AND d.dispatch_id IS NULL; + AND d.id IS NULL; IF inconsistent_count > 0 THEN RAISE NOTICE 'Found % transporters with inconsistent dispatch_status', inconsistent_count; diff --git a/db-migrations/20260215_pre_migration_check.sql b/db-migrations/20260215_pre_migration_check.sql index 8448f15..07aa69c 100644 --- a/db-migrations/20260215_pre_migration_check.sql +++ b/db-migrations/20260215_pre_migration_check.sql @@ -17,8 +17,8 @@ SELECT t.name as transporter_name, t.phone, t.dispatch_status, - COUNT(d.dispatch_id) as assigned_count, - STRING_AGG(d.dispatch_id::text, ', ' ORDER BY d.assigned_at DESC) as dispatch_ids, + COUNT(d.id) as assigned_count, + STRING_AGG(d.id::text, ', ' ORDER BY d.assigned_at DESC) as dispatch_ids, STRING_AGG(d.assigned_at::text, ', ' ORDER BY d.assigned_at DESC) as assigned_times, STRING_AGG(d.charge::text, ', ' ORDER BY d.assigned_at DESC) as charges FROM dispatch d @@ -27,8 +27,8 @@ WHERE d.status = 'ASSIGNED' AND d.active = true AND d.transporter_id IS NOT NULL GROUP BY t.transporter_id, t.name, t.phone, t.dispatch_status -HAVING COUNT(d.dispatch_id) > 1 -ORDER BY COUNT(d.dispatch_id) DESC, t.transporter_id; +HAVING COUNT(d.id) > 1 +ORDER BY COUNT(d.id) DESC, t.transporter_id; -- ================================================================ -- Check 2: 중복 배차 통계 @@ -64,8 +64,9 @@ SELECT '1. Has ASSIGNED dispatch but status is EMPTY' as inconsistency_type, t.transporter_id, t.name, + t.dispatch_status, - COUNT(d.dispatch_id) as assigned_dispatch_count + COUNT(d.id) as assigned_dispatch_count FROM transporters t JOIN dispatch d ON t.transporter_id = d.transporter_id WHERE d.status = 'ASSIGNED' @@ -87,7 +88,7 @@ LEFT JOIN dispatch d ON t.transporter_id = d.transporter_id AND d.status = 'ASSIGNED' AND d.active = true WHERE t.dispatch_status = 'DISPATCH' - AND d.dispatch_id IS NULL; + AND d.id IS NULL; -- ================================================================ -- Check 4: 중복 배차 상세 정보 (샘플 5건) @@ -96,7 +97,7 @@ SELECT '=== Sample Duplicate Dispatches (Top 5) ===' as check_title; SELECT - d.dispatch_id, + d.id, d.transporter_id, t.name as transporter_name, d.status,