- 400 → 422 для всех ошибок валидации входных данных (handlers: export, quote, sync, vendor_spec, partnumber_books, pricelist) - SQL-запросы вынесены из handlers в localdb (partnumber_books, pricelist, support_bundle); ValidateMariaDBConnection перенесён в internal/db/validate.go - List-ответы унифицированы: ключ items, поля total_count/page/per_page/total_pages (component, pricelist, partnumber_books); шаблоны обновлены - Молчаливые ошибки заменены на slog.Warn/Error (support_bundle, vendor_spec, component, configuration, local_configuration, localdb) - N+1 запросы устранены: batch-запросы в export.go и vendor_workspace_import.go - fmt.Println → slog в cmd/ (qfs, migrate, migrate_ops_projects, migrate_project_updated_at) - Заголовки recovery/verify добавлены во все 28 SQL-миграций - Добавлены bible-local/runtime-flows.md и bible-local/decisions/ - Обновлён субмодуль bible до v0.2.0-13 Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
45 lines
1.5 KiB
SQL
45 lines
1.5 KiB
SQL
-- Tables affected: qt_projects
|
|
-- recovery.not-started: check first; idempotent backfill but ADD COLUMN fails if code already exists
|
|
-- recovery.partial: ALTER TABLE qt_projects DROP INDEX idx_qt_projects_code; ALTER TABLE qt_projects DROP COLUMN code;
|
|
-- recovery.completed: no action needed
|
|
-- verify: code column in qt_projects missing | SELECT 1 FROM information_schema.COLUMNS WHERE table_schema=DATABASE() AND table_name='qt_projects' AND column_name='code' HAVING COUNT(*)=0
|
|
|
|
-- Add project code and enforce uniqueness
|
|
|
|
ALTER TABLE qt_projects
|
|
ADD COLUMN code VARCHAR(100) NULL AFTER owner_username;
|
|
|
|
-- Copy code from current project name (truncate to fit)
|
|
UPDATE qt_projects
|
|
SET code = LEFT(TRIM(COALESCE(name, '')), 100);
|
|
|
|
-- Fallback for any remaining blanks
|
|
UPDATE qt_projects
|
|
SET code = uuid
|
|
WHERE code IS NULL OR TRIM(code) = '';
|
|
|
|
-- Drop unique index if it already exists to allow de-duplication updates
|
|
DROP INDEX IF EXISTS idx_qt_projects_code ON qt_projects;
|
|
|
|
-- De-duplicate codes: OPS-1948-2, OPS-1948-3... (MariaDB without CTE)
|
|
UPDATE qt_projects p
|
|
JOIN (
|
|
SELECT p1.id,
|
|
p1.code AS base_code,
|
|
(
|
|
SELECT COUNT(*)
|
|
FROM qt_projects p2
|
|
WHERE p2.code = p1.code AND p2.id <= p1.id
|
|
) AS rn
|
|
FROM qt_projects p1
|
|
) r ON r.id = p.id
|
|
SET p.code = CASE
|
|
WHEN r.rn = 1 THEN r.base_code
|
|
ELSE CONCAT(LEFT(r.base_code, 90), '-', r.rn)
|
|
END;
|
|
|
|
ALTER TABLE qt_projects
|
|
MODIFY COLUMN code VARCHAR(100) NOT NULL;
|
|
|
|
CREATE UNIQUE INDEX idx_qt_projects_code ON qt_projects(code);
|