mirror of
https://gitlab.com/mbugroup/lti-api.git
synced 2026-05-20 13:31:56 +00:00
fix: all implemented fifo v2
This commit is contained in:
@@ -178,14 +178,35 @@ func main() {
|
||||
successApply++
|
||||
}
|
||||
|
||||
orphanPopulationRows := int64(0)
|
||||
syncedPopulationQtyRows := int64(0)
|
||||
syncedPopulationUsedRows := int64(0)
|
||||
if rowsOrphan, rowsQty, rowsUsed, err := resyncProjectFlockPopulation(ctx, db, projectFlockKandangID); err != nil {
|
||||
fmt.Printf("FAIL population_resync project_flock_kandang_id=%d error=%v\n", projectFlockKandangID, err)
|
||||
failedApply++
|
||||
} else {
|
||||
orphanPopulationRows = rowsOrphan
|
||||
syncedPopulationQtyRows = rowsQty
|
||||
syncedPopulationUsedRows = rowsUsed
|
||||
fmt.Printf(
|
||||
"SYNC project_flock_populations orphan_marked=%d qty_synced=%d used_synced=%d\n",
|
||||
orphanPopulationRows,
|
||||
syncedPopulationQtyRows,
|
||||
syncedPopulationUsedRows,
|
||||
)
|
||||
}
|
||||
|
||||
fmt.Println()
|
||||
fmt.Printf(
|
||||
"Summary: planned=%d skipped_pw=%d failed_resolve=%d applied=%d failed_apply=%d\n",
|
||||
"Summary: planned=%d skipped_pw=%d failed_resolve=%d applied=%d failed_apply=%d population_orphan=%d population_qty_synced=%d population_used_synced=%d\n",
|
||||
len(targets),
|
||||
skippedPW,
|
||||
failedResolve,
|
||||
successApply,
|
||||
failedApply,
|
||||
orphanPopulationRows,
|
||||
syncedPopulationQtyRows,
|
||||
syncedPopulationUsedRows,
|
||||
)
|
||||
if failedResolve > 0 || failedApply > 0 {
|
||||
os.Exit(1)
|
||||
@@ -379,3 +400,66 @@ func resolveFlagGroupsByProductWarehouse(ctx context.Context, db *gorm.DB, produ
|
||||
}
|
||||
return groups, nil
|
||||
}
|
||||
|
||||
func resyncProjectFlockPopulation(ctx context.Context, db *gorm.DB, projectFlockKandangID uint) (int64, int64, int64, error) {
|
||||
if projectFlockKandangID == 0 {
|
||||
return 0, 0, 0, nil
|
||||
}
|
||||
|
||||
orphanResult := db.WithContext(ctx).Exec(`
|
||||
UPDATE project_flock_populations pfp
|
||||
SET deleted_at = NOW(),
|
||||
updated_at = NOW()
|
||||
FROM project_chickins pc
|
||||
WHERE pfp.project_chickin_id = pc.id
|
||||
AND pc.project_flock_kandang_id = ?
|
||||
AND pc.deleted_at IS NOT NULL
|
||||
AND pfp.deleted_at IS NULL
|
||||
`, projectFlockKandangID)
|
||||
if orphanResult.Error != nil {
|
||||
return 0, 0, 0, orphanResult.Error
|
||||
}
|
||||
|
||||
qtyResult := db.WithContext(ctx).Exec(`
|
||||
UPDATE project_flock_populations p
|
||||
SET total_qty = GREATEST(COALESCE(pc.usage_qty, 0), 0),
|
||||
updated_at = NOW()
|
||||
FROM project_chickins pc
|
||||
WHERE p.project_chickin_id = pc.id
|
||||
AND pc.project_flock_kandang_id = ?
|
||||
AND pc.deleted_at IS NULL
|
||||
AND p.deleted_at IS NULL
|
||||
`, projectFlockKandangID)
|
||||
if qtyResult.Error != nil {
|
||||
return 0, 0, 0, qtyResult.Error
|
||||
}
|
||||
|
||||
usedResult := db.WithContext(ctx).Exec(`
|
||||
WITH scoped AS (
|
||||
SELECT pfp.id, pfp.total_qty
|
||||
FROM project_flock_populations pfp
|
||||
JOIN project_chickins pc ON pc.id = pfp.project_chickin_id
|
||||
WHERE pc.project_flock_kandang_id = ?
|
||||
AND pc.deleted_at IS NULL
|
||||
AND pfp.deleted_at IS NULL
|
||||
),
|
||||
alloc AS (
|
||||
SELECT sa.stockable_id, SUM(sa.qty) AS used_qty
|
||||
FROM stock_allocations sa
|
||||
WHERE sa.stockable_type = 'PROJECT_FLOCK_POPULATION'
|
||||
AND sa.status = 'ACTIVE'
|
||||
GROUP BY sa.stockable_id
|
||||
)
|
||||
UPDATE project_flock_populations p
|
||||
SET total_used_qty = LEAST(COALESCE(a.used_qty, 0), GREATEST(s.total_qty, 0)),
|
||||
updated_at = NOW()
|
||||
FROM scoped s
|
||||
LEFT JOIN alloc a ON a.stockable_id = s.id
|
||||
WHERE p.id = s.id
|
||||
`, projectFlockKandangID)
|
||||
if usedResult.Error != nil {
|
||||
return 0, 0, 0, usedResult.Error
|
||||
}
|
||||
|
||||
return orphanResult.RowsAffected, qtyResult.RowsAffected, usedResult.RowsAffected, nil
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user