Kamixitong/init_mysql.sql

223 lines
12 KiB
MySQL
Raw Normal View History

2025-11-22 16:48:45 +08:00
-- KaMiXiTong MySQL 数据库初始化脚本
-- 创建所有数据表结构
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for admin
-- ----------------------------
DROP TABLE IF EXISTS `admin`;
CREATE TABLE `admin` (
`admin_id` int NOT NULL AUTO_INCREMENT COMMENT '管理员ID',
`username` varchar(32) NOT NULL COMMENT '用户名',
`password_hash` varchar(128) NOT NULL COMMENT '密码哈希',
`email` varchar(64) DEFAULT NULL COMMENT '邮箱',
`role` int NOT NULL DEFAULT '0' COMMENT '角色: 0=普通管理员, 1=超级管理员',
`status` int NOT NULL DEFAULT '1' COMMENT '状态: 0=禁用, 1=正常',
`is_deleted` int NOT NULL DEFAULT '0' COMMENT '软删除: 0=未删除, 1=已删除',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`delete_time` datetime DEFAULT NULL COMMENT '删除时间',
`last_login_time` datetime DEFAULT NULL COMMENT '最后登录时间',
`last_login_ip` varchar(32) DEFAULT NULL COMMENT '最后登录IP',
PRIMARY KEY (`admin_id`),
UNIQUE KEY `uk_username` (`username`),
KEY `idx_username` (`username`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='管理员表';
-- ----------------------------
-- Table structure for product
-- ----------------------------
DROP TABLE IF EXISTS `product`;
CREATE TABLE `product` (
`product_id` varchar(32) NOT NULL COMMENT '产品ID',
`product_name` varchar(64) NOT NULL COMMENT '产品名称',
`description` text COMMENT '产品描述',
`image_path` varchar(255) DEFAULT NULL COMMENT '产品图片路径',
`status` int NOT NULL DEFAULT '1' COMMENT '状态: 0=禁用, 1=启用',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
PRIMARY KEY (`product_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='产品表';
-- ----------------------------
-- Table structure for version
-- ----------------------------
DROP TABLE IF EXISTS `version`;
CREATE TABLE `version` (
`version_id` int NOT NULL AUTO_INCREMENT COMMENT '版本ID',
`product_id` varchar(32) NOT NULL COMMENT '产品ID',
`version_num` varchar(16) NOT NULL COMMENT '版本号',
`platform` varchar(32) DEFAULT NULL COMMENT '平台信息',
`description` text COMMENT '版本描述',
`update_log` text COMMENT '更新日志',
`download_url` varchar(255) DEFAULT NULL COMMENT '下载地址',
`min_license_version` varchar(16) DEFAULT NULL COMMENT '最低兼容卡密版本',
`force_update` int NOT NULL DEFAULT '0' COMMENT '强制更新: 0=否, 1=是',
`download_status` int NOT NULL DEFAULT '1' COMMENT '下载状态: 0=禁用, 1=启用',
`publish_status` int NOT NULL DEFAULT '0' COMMENT '发布状态: 0=草稿, 1=已发布, 2=已回滚',
`file_hash` varchar(64) DEFAULT NULL COMMENT '文件SHA256哈希值',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
PRIMARY KEY (`version_id`),
UNIQUE KEY `uk_product_version` (`product_id`,`version_num`),
CONSTRAINT `fk_version_product` FOREIGN KEY (`product_id`) REFERENCES `product` (`product_id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='版本表';
-- ----------------------------
-- Table structure for license
-- ----------------------------
DROP TABLE IF EXISTS `license`;
CREATE TABLE `license` (
`license_id` int NOT NULL AUTO_INCREMENT COMMENT '卡密ID',
`license_key` varchar(35) NOT NULL COMMENT '卡密格式XXXX-XXXX-XXXX-XXXX',
`product_id` varchar(32) NOT NULL COMMENT '产品ID',
`type` int NOT NULL DEFAULT '1' COMMENT '类型: 0=试用, 1=正式',
`status` int NOT NULL DEFAULT '0' COMMENT '状态: 0=未激活, 1=已激活, 2=已过期, 3=已禁用',
`valid_days` int NOT NULL COMMENT '有效期(天,-1=永久)',
`bind_machine_code` varchar(64) DEFAULT NULL COMMENT '绑定的机器码',
`activate_time` datetime DEFAULT NULL COMMENT '激活时间',
`expire_time` datetime DEFAULT NULL COMMENT '过期时间',
`last_verify_time` datetime DEFAULT NULL COMMENT '最后验证时间',
`unbind_count` int DEFAULT '0' COMMENT '解绑次数',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
PRIMARY KEY (`license_id`),
UNIQUE KEY `uk_license_key` (`license_key`),
KEY `idx_license_key` (`license_key`),
KEY `idx_product_id` (`product_id`),
CONSTRAINT `fk_license_product` FOREIGN KEY (`product_id`) REFERENCES `product` (`product_id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='卡密表';
-- ----------------------------
-- Table structure for device
-- ----------------------------
DROP TABLE IF EXISTS `device`;
CREATE TABLE `device` (
`device_id` int NOT NULL AUTO_INCREMENT COMMENT '设备ID',
`machine_code` varchar(64) NOT NULL COMMENT '机器码',
`license_id` int DEFAULT NULL COMMENT '卡密ID',
`product_id` varchar(32) NOT NULL COMMENT '产品ID',
`software_version` varchar(16) DEFAULT NULL COMMENT '软件版本',
`ip_address` varchar(45) DEFAULT NULL COMMENT 'IP地址',
`status` int NOT NULL DEFAULT '1' COMMENT '状态: 0=禁用, 1=正常',
`activate_time` datetime DEFAULT NULL COMMENT '激活时间',
`last_verify_time` datetime DEFAULT NULL COMMENT '最后验证时间',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
PRIMARY KEY (`device_id`),
UNIQUE KEY `uk_machine_code` (`machine_code`),
KEY `idx_machine_code` (`machine_code`),
KEY `idx_license_id` (`license_id`),
KEY `idx_product_id` (`product_id`),
CONSTRAINT `fk_device_license` FOREIGN KEY (`license_id`) REFERENCES `license` (`license_id`) ON DELETE SET NULL,
CONSTRAINT `fk_device_product` FOREIGN KEY (`product_id`) REFERENCES `product` (`product_id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='设备表';
-- ----------------------------
-- Table structure for ticket
-- ----------------------------
DROP TABLE IF EXISTS `ticket`;
CREATE TABLE `ticket` (
`ticket_id` int NOT NULL AUTO_INCREMENT COMMENT '工单ID',
`title` varchar(128) NOT NULL COMMENT '标题',
`product_id` varchar(32) NOT NULL COMMENT '产品ID',
`software_version` varchar(16) DEFAULT NULL COMMENT '软件版本',
`machine_code` varchar(64) DEFAULT NULL COMMENT '机器码',
`license_key` varchar(32) DEFAULT NULL COMMENT '卡密',
`description` text NOT NULL COMMENT '描述',
`priority` int NOT NULL DEFAULT '1' COMMENT '优先级: 0=低, 1=中, 2=高',
`status` int NOT NULL DEFAULT '0' COMMENT '状态: 0=待处理, 1=处理中, 2=已解决, 3=已关闭',
`operator` varchar(32) DEFAULT NULL COMMENT '处理人(管理员账号)',
`remark` text COMMENT '处理备注',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
`resolve_time` datetime DEFAULT NULL COMMENT '解决时间',
`close_time` datetime DEFAULT NULL COMMENT '关闭时间',
PRIMARY KEY (`ticket_id`),
KEY `idx_product_id` (`product_id`),
CONSTRAINT `fk_ticket_product` FOREIGN KEY (`product_id`) REFERENCES `product` (`product_id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='工单表';
-- ----------------------------
-- Table structure for audit_log
-- ----------------------------
DROP TABLE IF EXISTS `audit_log`;
CREATE TABLE `audit_log` (
`log_id` int NOT NULL AUTO_INCREMENT COMMENT '日志ID',
`admin_id` int NOT NULL COMMENT '管理员ID',
`action` varchar(32) NOT NULL COMMENT '操作类型',
`target_type` varchar(32) NOT NULL COMMENT '目标类型',
`target_id` varchar(32) DEFAULT NULL COMMENT '目标ID',
`details` text COMMENT '操作详情JSON格式',
`ip_address` varchar(32) DEFAULT NULL COMMENT '操作IP地址',
`user_agent` varchar(256) DEFAULT NULL COMMENT '用户代理',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
PRIMARY KEY (`log_id`),
KEY `idx_admin_id` (`admin_id`),
KEY `idx_create_time` (`create_time`),
CONSTRAINT `fk_audit_log_admin` FOREIGN KEY (`admin_id`) REFERENCES `admin` (`admin_id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='审计日志表';
-- ----------------------------
-- Table structure for `order`
-- ----------------------------
DROP TABLE IF EXISTS `order`;
CREATE TABLE `order` (
`order_id` int NOT NULL AUTO_INCREMENT COMMENT '订单ID',
`order_number` varchar(32) NOT NULL COMMENT '订单号',
`product_id` varchar(32) NOT NULL COMMENT '产品ID',
`package_id` varchar(64) NOT NULL COMMENT '套餐ID',
`contact_person` varchar(64) NOT NULL COMMENT '联系人',
`phone` varchar(20) NOT NULL COMMENT '手机号',
`quantity` int NOT NULL DEFAULT '1' COMMENT '数量',
`amount` float NOT NULL COMMENT '金额',
`status` int NOT NULL DEFAULT '0' COMMENT '状态: 0=待支付, 1=已支付, 2=已取消, 3=已完成',
`payment_method` varchar(20) DEFAULT NULL COMMENT '支付方式',
`payment_time` datetime DEFAULT NULL COMMENT '支付时间',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
PRIMARY KEY (`order_id`),
UNIQUE KEY `uk_order_number` (`order_number`),
KEY `idx_order_number` (`order_number`),
KEY `idx_product_id` (`product_id`),
CONSTRAINT `fk_order_product` FOREIGN KEY (`product_id`) REFERENCES `product` (`product_id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='订单表';
-- ----------------------------
-- Table structure for package
-- ----------------------------
DROP TABLE IF EXISTS `package`;
CREATE TABLE `package` (
`package_id` varchar(64) NOT NULL COMMENT '套餐ID',
`product_id` varchar(32) NOT NULL COMMENT '产品ID',
`name` varchar(64) NOT NULL COMMENT '套餐名称',
`description` text COMMENT '套餐描述',
`price` float NOT NULL COMMENT '价格',
`duration` int NOT NULL COMMENT '时长(天)',
`max_devices` int NOT NULL DEFAULT '1' COMMENT '最大设备数',
`stock` int NOT NULL DEFAULT '-1' COMMENT '库存,-1表示无限',
`status` int NOT NULL DEFAULT '1' COMMENT '状态: 0=禁用, 1=启用',
`sort_order` int NOT NULL DEFAULT '0' COMMENT '排序',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
PRIMARY KEY (`package_id`),
KEY `idx_product_id` (`product_id`),
CONSTRAINT `fk_package_product` FOREIGN KEY (`product_id`) REFERENCES `product` (`product_id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='产品套餐表';
-- ----------------------------
-- 插入默认管理员账号
-- ----------------------------
INSERT INTO `admin` (`username`, `password_hash`, `email`, `role`, `status`, `create_time`)
VALUES ('admin', '$pbkdf2-sha256$29000$N2YMIWQwJjd8Lgh0fDho3w$O.2GhbxpZb8tI1x2O5E0y/QE1Q6j5J6k8v2J3F1x9hQ', 'admin@example.com', 1, 1, NOW());
-- ----------------------------
-- 插入默认产品示例
-- ----------------------------
INSERT INTO `product` (`product_id`, `product_name`, `description`, `status`, `create_time`)
VALUES ('PROD_SAMPLE', '示例产品', '这是一个示例产品', 1, NOW());
SET FOREIGN_KEY_CHECKS = 1;