HaniBlindBox/server/scripts/validate_order_tables.sql
2026-01-02 05:18:05 +08:00

299 lines
10 KiB
Transact-SQL

-- ============================================================
-- 订单系统表结构验证脚本
-- Feature: database-migration, Property 1: 表结构完整性
-- Validates: Requirements 3.1, 3.2, 3.3, 3.4
-- ============================================================
SET NOCOUNT ON;
PRINT '========================================';
PRINT '订单系统表结构验证报告';
PRINT '执行时间: ' + CONVERT(VARCHAR, GETDATE(), 120);
PRINT '========================================';
PRINT '';
-- ============================================================
-- 1. 验证表是否存在
-- ============================================================
PRINT '1. 验证表是否存在';
PRINT '----------------------------------------';
DECLARE @orders_exists BIT = 0;
DECLARE @order_items_exists BIT = 0;
DECLARE @order_items_recovery_exists BIT = 0;
DECLARE @order_items_send_exists BIT = 0;
IF EXISTS (SELECT 1 FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = 'orders')
BEGIN
SET @orders_exists = 1;
PRINT '✓ orders 表存在';
END
ELSE
PRINT '✗ orders 表不存在';
IF EXISTS (SELECT 1 FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = 'order_items')
BEGIN
SET @order_items_exists = 1;
PRINT '✓ order_items 表存在';
END
ELSE
PRINT '✗ order_items 表不存在';
IF EXISTS (SELECT 1 FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = 'order_items_recovery')
BEGIN
SET @order_items_recovery_exists = 1;
PRINT '✓ order_items_recovery 表存在';
END
ELSE
PRINT '✗ order_items_recovery 表不存在';
IF EXISTS (SELECT 1 FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = 'order_items_send')
BEGIN
SET @order_items_send_exists = 1;
PRINT '✓ order_items_send 表存在';
END
ELSE
PRINT '✗ order_items_send 表不存在';
PRINT '';
-- ============================================================
-- 2. 验证字段数量
-- ============================================================
PRINT '2. 验证字段数量';
PRINT '----------------------------------------';
SELECT
TABLE_NAME AS '表名',
COUNT(*) AS '字段数量',
CASE TABLE_NAME
WHEN 'orders' THEN '>=35'
WHEN 'order_items' THEN '>=31'
WHEN 'order_items_recovery' THEN '>=6'
WHEN 'order_items_send' THEN '>=22'
END AS '预期字段数',
CASE
WHEN TABLE_NAME = 'orders' AND COUNT(*) >= 35 THEN '✓ 通过'
WHEN TABLE_NAME = 'order_items' AND COUNT(*) >= 31 THEN '✓ 通过'
WHEN TABLE_NAME = 'order_items_recovery' AND COUNT(*) >= 6 THEN '✓ 通过'
WHEN TABLE_NAME = 'order_items_send' AND COUNT(*) >= 22 THEN '✓ 通过'
ELSE '✗ 失败'
END AS '验证结果'
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME IN ('orders', 'order_items', 'order_items_recovery', 'order_items_send')
GROUP BY TABLE_NAME
ORDER BY TABLE_NAME;
PRINT '';
-- ============================================================
-- 3. 验证主键约束
-- ============================================================
PRINT '3. 验证主键约束';
PRINT '----------------------------------------';
SELECT
t.name AS '表名',
c.name AS '主键列',
i.name AS '主键名称',
'✓ 存在' AS '验证结果'
FROM sys.tables t
INNER JOIN sys.indexes i ON t.object_id = i.object_id AND i.is_primary_key = 1
INNER JOIN sys.index_columns ic ON i.object_id = ic.object_id AND i.index_id = ic.index_id
INNER JOIN sys.columns c ON ic.object_id = c.object_id AND ic.column_id = c.column_id
WHERE t.name IN ('orders', 'order_items', 'order_items_recovery', 'order_items_send')
ORDER BY t.name;
PRINT '';
-- ============================================================
-- 4. 验证唯一约束
-- ============================================================
PRINT '4. 验证唯一约束';
PRINT '----------------------------------------';
SELECT
t.name AS '表名',
i.name AS '约束名称',
c.name AS '约束列',
'✓ 存在' AS '验证结果'
FROM sys.tables t
INNER JOIN sys.indexes i ON t.object_id = i.object_id AND i.is_unique = 1 AND i.is_primary_key = 0
INNER JOIN sys.index_columns ic ON i.object_id = ic.object_id AND i.index_id = ic.index_id
INNER JOIN sys.columns c ON ic.object_id = c.object_id AND ic.column_id = c.column_id
WHERE t.name IN ('orders', 'order_items', 'order_items_recovery', 'order_items_send')
ORDER BY t.name, i.name;
PRINT '';
-- ============================================================
-- 5. 验证索引
-- ============================================================
PRINT '5. 验证索引';
PRINT '----------------------------------------';
SELECT
t.name AS '表名',
i.name AS '索引名称',
i.type_desc AS '索引类型'
FROM sys.indexes i
INNER JOIN sys.tables t ON i.object_id = t.object_id
WHERE t.name IN ('orders', 'order_items', 'order_items_recovery', 'order_items_send')
AND i.name IS NOT NULL
ORDER BY t.name, i.name;
PRINT '';
-- ============================================================
-- 6. 验证表注释
-- ============================================================
PRINT '6. 验证表注释';
PRINT '----------------------------------------';
SELECT
t.name AS '表名',
CAST(ep.value AS NVARCHAR(500)) AS '表注释',
CASE WHEN ep.value IS NOT NULL THEN '✓ 存在' ELSE '✗ 缺失' END AS '验证结果'
FROM sys.tables t
LEFT JOIN sys.extended_properties ep ON ep.major_id = t.object_id AND ep.minor_id = 0 AND ep.name = 'MS_Description'
WHERE t.name IN ('orders', 'order_items', 'order_items_recovery', 'order_items_send')
ORDER BY t.name;
PRINT '';
-- ============================================================
-- 7. 验证关键字段注释数量
-- ============================================================
PRINT '7. 验证关键字段注释数量';
PRINT '----------------------------------------';
SELECT
t.name AS '表名',
COUNT(ep.value) AS '有注释的字段数',
(SELECT COUNT(*) FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = t.name) AS '总字段数'
FROM sys.tables t
LEFT JOIN sys.columns c ON t.object_id = c.object_id
LEFT JOIN sys.extended_properties ep ON ep.major_id = c.object_id AND ep.minor_id = c.column_id AND ep.name = 'MS_Description'
WHERE t.name IN ('orders', 'order_items', 'order_items_recovery', 'order_items_send')
GROUP BY t.name
ORDER BY t.name;
PRINT '';
-- ============================================================
-- 8. 验证支付方式组合字段 (Requirements 3.5)
-- ============================================================
PRINT '8. 验证支付方式组合字段';
PRINT '----------------------------------------';
DECLARE @payment_fields INT = 0;
SELECT @payment_fields = COUNT(*)
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = 'orders'
AND COLUMN_NAME IN ('use_money', 'use_integral', 'use_score', 'use_coupon', 'use_money2', 'use_draw', 'use_item_card');
IF @payment_fields >= 7
PRINT '✓ 支付方式组合字段完整 (use_money, use_integral, use_score, use_coupon, use_money2, use_draw, use_item_card)';
ELSE
PRINT '✗ 支付方式组合字段不完整 (当前: ' + CAST(@payment_fields AS VARCHAR) + '/7)';
PRINT '';
-- ============================================================
-- 9. 验证订单状态和类型字段
-- ============================================================
PRINT '9. 验证订单状态和类型字段';
PRINT '----------------------------------------';
DECLARE @status_fields INT = 0;
SELECT @status_fields = COUNT(*)
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = 'orders'
AND COLUMN_NAME IN ('status', 'pay_type', 'order_type', 'is_flw', 'is_mibao', 'is_shou_zhe');
IF @status_fields >= 6
PRINT '✓ 订单状态和类型字段完整 (status, pay_type, order_type, is_flw, is_mibao, is_shou_zhe)';
ELSE
PRINT '✗ 订单状态和类型字段不完整 (当前: ' + CAST(@status_fields AS VARCHAR) + '/6)';
PRINT '';
-- ============================================================
-- 10. 验证订单详情关键字段
-- ============================================================
PRINT '10. 验证订单详情关键字段';
PRINT '----------------------------------------';
DECLARE @order_items_key_fields INT = 0;
SELECT @order_items_key_fields = COUNT(*)
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = 'order_items'
AND COLUMN_NAME IN ('order_id', 'user_id', 'goods_id', 'shang_id', 'goodslist_id', 'status', 'recovery_num', 'send_num');
IF @order_items_key_fields >= 8
PRINT '✓ 订单详情关键字段完整 (order_id, user_id, goods_id, shang_id, goodslist_id, status, recovery_num, send_num)';
ELSE
PRINT '✗ 订单详情关键字段不完整 (当前: ' + CAST(@order_items_key_fields AS VARCHAR) + '/8)';
PRINT '';
-- ============================================================
-- 11. 验证发货记录关键字段
-- ============================================================
PRINT '11. 验证发货记录关键字段';
PRINT '----------------------------------------';
DECLARE @send_key_fields INT = 0;
SELECT @send_key_fields = COUNT(*)
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = 'order_items_send'
AND COLUMN_NAME IN ('user_id', 'send_num', 'status', 'name', 'mobile', 'address', 'courier_number', 'courier_name');
IF @send_key_fields >= 8
PRINT '✓ 发货记录关键字段完整 (user_id, send_num, status, name, mobile, address, courier_number, courier_name)';
ELSE
PRINT '✗ 发货记录关键字段不完整 (当前: ' + CAST(@send_key_fields AS VARCHAR) + '/8)';
PRINT '';
-- ============================================================
-- 验证总结
-- ============================================================
PRINT '========================================';
PRINT '验证总结';
PRINT '========================================';
DECLARE @total_tables INT = @orders_exists + @order_items_exists + @order_items_recovery_exists + @order_items_send_exists;
IF @total_tables = 4
PRINT '✓ 所有订单系统表创建成功 (4/4)';
ELSE
PRINT '✗ 部分表创建失败 (' + CAST(@total_tables AS VARCHAR) + '/4)';
IF @payment_fields >= 7
PRINT '✓ 支付方式组合字段完整';
ELSE
PRINT '✗ 支付方式组合字段不完整';
IF @status_fields >= 6
PRINT '✓ 订单状态和类型字段完整';
ELSE
PRINT '✗ 订单状态和类型字段不完整';
IF @order_items_key_fields >= 8
PRINT '✓ 订单详情关键字段完整';
ELSE
PRINT '✗ 订单详情关键字段不完整';
IF @send_key_fields >= 8
PRINT '✓ 发货记录关键字段完整';
ELSE
PRINT '✗ 发货记录关键字段不完整';
PRINT '';
PRINT '验证完成!';