- 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>
32 lines
1.3 KiB
SQL
32 lines
1.3 KiB
SQL
-- Tables affected: qt_configurations
|
|
-- recovery.not-started: safe to re-run; uses INFORMATION_SCHEMA check before DROP FOREIGN KEY
|
|
-- recovery.partial: no rollback needed; FK was dropped intentionally
|
|
-- recovery.completed: no action needed
|
|
-- verify: user_id column is still NOT NULL | SELECT 1 FROM information_schema.COLUMNS WHERE table_schema=DATABASE() AND table_name='qt_configurations' AND column_name='user_id' AND is_nullable='NO' HAVING COUNT(*)>0
|
|
|
|
-- Detach qt_configurations from qt_users (ownership is owner_username text)
|
|
-- Safe for MySQL 8+/MariaDB 10.2+ via INFORMATION_SCHEMA checks.
|
|
|
|
SET @fk_exists := (
|
|
SELECT COUNT(*)
|
|
FROM information_schema.TABLE_CONSTRAINTS
|
|
WHERE CONSTRAINT_SCHEMA = DATABASE()
|
|
AND TABLE_NAME = 'qt_configurations'
|
|
AND CONSTRAINT_NAME = 'fk_qt_configurations_user'
|
|
AND CONSTRAINT_TYPE = 'FOREIGN KEY'
|
|
);
|
|
|
|
SET @drop_fk_sql := IF(
|
|
@fk_exists > 0,
|
|
'ALTER TABLE qt_configurations DROP FOREIGN KEY fk_qt_configurations_user',
|
|
'SELECT ''fk_qt_configurations_user not found, skip'' '
|
|
);
|
|
PREPARE stmt_drop_fk FROM @drop_fk_sql;
|
|
EXECUTE stmt_drop_fk;
|
|
DEALLOCATE PREPARE stmt_drop_fk;
|
|
|
|
-- user_id becomes optional legacy column (can stay NULL)
|
|
ALTER TABLE qt_configurations
|
|
MODIFY COLUMN user_id BIGINT UNSIGNED NULL;
|
|
|