Files
ai_dianshang/server/migrations/001_create_refund_table.sql

106 lines
6.0 KiB
MySQL
Raw Permalink Normal View History

2025-11-17 13:32:54 +08:00
-- 创建退款记录表
-- 执行时间: 2024-01-01
-- 描述: 为微信退款功能创建退款记录表,记录所有退款申请和处理状态
CREATE TABLE IF NOT EXISTS `ai_refunds` (
`id` bigint unsigned NOT NULL AUTO_INCREMENT COMMENT '退款记录ID',
`refund_no` varchar(64) NOT NULL COMMENT '退款单号,系统生成的唯一退款编号',
`order_id` bigint unsigned NOT NULL COMMENT '关联订单ID',
`order_no` varchar(32) NOT NULL COMMENT '订单号',
`user_id` bigint unsigned NOT NULL COMMENT '用户ID',
`refund_type` tinyint NOT NULL DEFAULT 1 COMMENT '退款类型1=仅退款2=退货退款',
`refund_reason` varchar(255) NOT NULL COMMENT '退款原因',
`refund_description` text COMMENT '退款详细说明',
`refund_amount` decimal(10,2) NOT NULL COMMENT '退款金额(分)',
`refund_fee` decimal(10,2) DEFAULT 0.00 COMMENT '退款手续费(分)',
`actual_refund_amount` decimal(10,2) NOT NULL COMMENT '实际退款金额(分)',
`status` tinyint NOT NULL DEFAULT 1 COMMENT '退款状态1=待审核2=审核通过3=审核拒绝4=退款中5=退款成功6=退款失败',
`apply_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '申请时间',
`audit_time` timestamp NULL COMMENT '审核时间',
`refund_time` timestamp NULL COMMENT '退款完成时间',
`admin_id` bigint unsigned NULL COMMENT '审核管理员ID',
`admin_remark` text COMMENT '管理员备注',
`reject_reason` varchar(255) NULL COMMENT '拒绝原因',
-- 微信退款相关字段
`wechat_refund_id` varchar(64) NULL COMMENT '微信退款单号',
`wechat_out_refund_no` varchar(64) NULL COMMENT '商户退款单号',
`wechat_transaction_id` varchar(64) NULL COMMENT '微信支付交易号',
`wechat_refund_status` varchar(32) NULL COMMENT '微信退款状态SUCCESS=成功CLOSED=关闭PROCESSING=处理中',
`wechat_refund_recv_accout` varchar(64) NULL COMMENT '退款入账账户',
`wechat_success_time` timestamp NULL COMMENT '微信退款成功时间',
`wechat_user_received_account` varchar(64) NULL COMMENT '退款到账账户',
`wechat_refund_account` varchar(32) NULL COMMENT '退款资金来源AVAILABLE=可用余额UNAVAILABLE=不可用余额',
-- 退货相关字段当refund_type=2时使用
`return_logistics_company` varchar(50) NULL COMMENT '退货物流公司',
`return_logistics_no` varchar(100) NULL COMMENT '退货物流单号',
`return_address` varchar(255) NULL COMMENT '退货地址',
`goods_received_time` timestamp NULL COMMENT '商家收货时间',
-- 图片证据
`evidence_images` json NULL COMMENT '退款凭证图片JSON数组',
`created_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updated_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
PRIMARY KEY (`id`),
UNIQUE KEY `uk_refund_no` (`refund_no`),
UNIQUE KEY `uk_wechat_out_refund_no` (`wechat_out_refund_no`),
KEY `idx_order_id` (`order_id`),
KEY `idx_order_no` (`order_no`),
KEY `idx_user_id` (`user_id`),
KEY `idx_status` (`status`),
KEY `idx_apply_time` (`apply_time`),
KEY `idx_wechat_refund_id` (`wechat_refund_id`),
KEY `idx_wechat_transaction_id` (`wechat_transaction_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='退款记录表';
-- 为订单表添加退款相关字段(如果不存在)
ALTER TABLE `ai_orders`
ADD COLUMN IF NOT EXISTS `refunded_at` timestamp NULL COMMENT '退款时间' AFTER `refund_time`,
ADD COLUMN IF NOT EXISTS `total_refund_amount` decimal(10,2) DEFAULT 0.00 COMMENT '累计退款金额' AFTER `refund_amount`,
ADD COLUMN IF NOT EXISTS `refund_count` int DEFAULT 0 COMMENT '退款次数' AFTER `total_refund_amount`;
-- 创建退款项目表(支持部分退款)
CREATE TABLE IF NOT EXISTS `ai_refund_items` (
`id` bigint unsigned NOT NULL AUTO_INCREMENT COMMENT '退款项目ID',
`refund_id` bigint unsigned NOT NULL COMMENT '退款记录ID',
`order_item_id` bigint unsigned NOT NULL COMMENT '订单项ID',
`product_id` bigint unsigned NOT NULL COMMENT '商品ID',
`sku_id` bigint unsigned NULL COMMENT 'SKU ID',
`product_name` varchar(100) NOT NULL COMMENT '商品名称',
`product_image` varchar(255) NULL COMMENT '商品图片',
`spec_info` json NULL COMMENT '规格信息',
`quantity` int NOT NULL COMMENT '退款数量',
`unit_price` decimal(10,2) NOT NULL COMMENT '单价(分)',
`total_price` decimal(10,2) NOT NULL COMMENT '退款总价(分)',
`created_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`updated_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
PRIMARY KEY (`id`),
KEY `idx_refund_id` (`refund_id`),
KEY `idx_order_item_id` (`order_item_id`),
KEY `idx_product_id` (`product_id`),
FOREIGN KEY (`refund_id`) REFERENCES `ai_refunds` (`id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='退款项目表';
-- 创建退款日志表
CREATE TABLE IF NOT EXISTS `ai_refund_logs` (
`id` bigint unsigned NOT NULL AUTO_INCREMENT COMMENT '日志ID',
`refund_id` bigint unsigned NOT NULL COMMENT '退款记录ID',
`action` varchar(50) NOT NULL COMMENT '操作类型apply=申请audit=审核refund=退款callback=回调',
`status_from` tinyint NULL COMMENT '状态变更前',
`status_to` tinyint NULL COMMENT '状态变更后',
`operator_type` varchar(20) NOT NULL COMMENT '操作者类型user=用户admin=管理员system=系统',
`operator_id` bigint unsigned NULL COMMENT '操作者ID',
`remark` text NULL COMMENT '操作备注',
`extra_data` json NULL COMMENT '额外数据',
`created_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
PRIMARY KEY (`id`),
KEY `idx_refund_id` (`refund_id`),
KEY `idx_action` (`action`),
KEY `idx_created_at` (`created_at`),
FOREIGN KEY (`refund_id`) REFERENCES `ai_refunds` (`id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='退款操作日志表';