增加微信支付,商城逻辑,公告
This commit is contained in:
17
migrations/add_alipay_support.sql
Normal file
17
migrations/add_alipay_support.sql
Normal file
@@ -0,0 +1,17 @@
|
||||
-- 为支付订单表添加支付宝支持
|
||||
-- 更新交易类型枚举,添加支付宝相关类型
|
||||
ALTER TABLE `payment_orders` MODIFY COLUMN `trade_type` varchar(32) NOT NULL COMMENT '交易类型(H5/JSAPI/ALIPAY_WAP/ALIPAY_APP等)';
|
||||
|
||||
-- 更新transaction_id字段注释,支持多种支付方式
|
||||
ALTER TABLE `payment_orders` MODIFY COLUMN `transaction_id` varchar(64) DEFAULT NULL COMMENT '第三方支付订单号(微信/支付宝)';
|
||||
|
||||
-- 添加支付方式字段
|
||||
ALTER TABLE `payment_orders` ADD COLUMN `payment_method` enum('wechat','alipay') DEFAULT 'wechat' COMMENT '支付方式' AFTER `trade_type`;
|
||||
|
||||
-- 添加支付宝特有字段
|
||||
ALTER TABLE `payment_orders` ADD COLUMN `buyer_user_id` varchar(32) DEFAULT NULL COMMENT '支付宝买家用户ID' AFTER `transaction_id`;
|
||||
ALTER TABLE `payment_orders` ADD COLUMN `trade_status` varchar(32) DEFAULT NULL COMMENT '支付宝交易状态' AFTER `buyer_user_id`;
|
||||
|
||||
-- 添加索引
|
||||
ALTER TABLE `payment_orders` ADD KEY `idx_payment_method` (`payment_method`);
|
||||
ALTER TABLE `payment_orders` ADD KEY `idx_trade_status` (`trade_status`);
|
||||
27
migrations/create_payment_orders_table.sql
Normal file
27
migrations/create_payment_orders_table.sql
Normal file
@@ -0,0 +1,27 @@
|
||||
-- 创建支付订单表
|
||||
CREATE TABLE IF NOT EXISTS `payment_orders` (
|
||||
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '订单ID',
|
||||
`user_id` int(11) NOT NULL COMMENT '用户ID',
|
||||
`out_trade_no` varchar(64) NOT NULL COMMENT '商户订单号',
|
||||
`transaction_id` varchar(64) DEFAULT NULL COMMENT '微信支付订单号',
|
||||
`total_fee` int(11) NOT NULL COMMENT '订单金额(分)',
|
||||
`body` varchar(128) NOT NULL COMMENT '商品描述',
|
||||
`trade_type` varchar(16) NOT NULL COMMENT '交易类型',
|
||||
`prepay_id` varchar(64) DEFAULT NULL COMMENT '预支付交易会话标识',
|
||||
`mweb_url` text DEFAULT NULL COMMENT 'H5支付跳转链接',
|
||||
`status` enum('pending','paid','failed','cancelled') NOT NULL DEFAULT 'pending' COMMENT '支付状态',
|
||||
`paid_at` datetime DEFAULT NULL COMMENT '支付完成时间',
|
||||
`created_at` datetime NOT NULL COMMENT '创建时间',
|
||||
`updated_at` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
|
||||
PRIMARY KEY (`id`),
|
||||
UNIQUE KEY `uk_out_trade_no` (`out_trade_no`),
|
||||
KEY `idx_user_id` (`user_id`),
|
||||
KEY `idx_status` (`status`),
|
||||
KEY `idx_created_at` (`created_at`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='支付订单表';
|
||||
|
||||
-- 为用户表添加支付状态字段
|
||||
ALTER TABLE `users` ADD COLUMN `payment_status` enum('unpaid','paid') NOT NULL DEFAULT 'unpaid' COMMENT '支付状态' AFTER `status`;
|
||||
|
||||
-- 添加索引
|
||||
ALTER TABLE `users` ADD KEY `idx_payment_status` (`payment_status`);
|
||||
Reference in New Issue
Block a user