- 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>
21 lines
804 B
SQL
21 lines
804 B
SQL
-- Tables affected: stock_log
|
|
-- recovery.not-started: safe to re-run; CREATE TABLE IF NOT EXISTS
|
|
-- recovery.partial: DROP TABLE IF EXISTS stock_log;
|
|
-- recovery.completed: no action needed
|
|
-- verify: stock_log table missing | SELECT 1 FROM information_schema.TABLES WHERE table_schema=DATABASE() AND table_name='stock_log' HAVING COUNT(*)=0
|
|
|
|
CREATE TABLE IF NOT EXISTS stock_log (
|
|
stock_log_id BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
|
|
lot VARCHAR(255) NOT NULL,
|
|
supplier VARCHAR(255) NULL,
|
|
date DATE NOT NULL,
|
|
price DECIMAL(12,2) NOT NULL,
|
|
quality VARCHAR(255) NULL,
|
|
comments TEXT NULL,
|
|
vendor VARCHAR(255) NULL,
|
|
qty DECIMAL(14,3) NULL,
|
|
INDEX idx_stock_log_lot_date (lot, date),
|
|
INDEX idx_stock_log_date (date),
|
|
INDEX idx_stock_log_vendor (vendor)
|
|
);
|