/* Navicat Premium Dump SQL Source Server : localhost Source Server Type : MySQL Source Server Version : 80043 (8.0.43) Source Host : localhost:3306 Source Schema : login_task_db Target Server Type : MySQL Target Server Version : 80043 (8.0.43) File Encoding : 65001 Date: 24/08/2025 19:08:50 */ SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for agent_points_tx -- ---------------------------- DROP TABLE IF EXISTS `agent_points_tx`; CREATE TABLE `agent_points_tx` ( `id` bigint UNSIGNED NOT NULL AUTO_INCREMENT, `account_id` bigint UNSIGNED NOT NULL, `type` enum('ADD','DEDUCT') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL, `before_points` bigint UNSIGNED NOT NULL, `delta_points` bigint NOT NULL, `after_points` bigint UNSIGNED NOT NULL, `reason` enum('create_links','manual','refund_no_rollback','other') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL DEFAULT 'other', `ref_id` bigint UNSIGNED NULL DEFAULT NULL, `operator_id` bigint UNSIGNED NULL DEFAULT NULL, `created_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3), PRIMARY KEY (`id`) USING BTREE, INDEX `idx_apx_account_time`(`account_id` ASC, `created_at` ASC) USING BTREE, INDEX `fk_apx_operator`(`operator_id` ASC) USING BTREE, CONSTRAINT `fk_apx_account` FOREIGN KEY (`account_id`) REFERENCES `user_account` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT `fk_apx_operator` FOREIGN KEY (`operator_id`) REFERENCES `user_account` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic; -- ---------------------------- -- Table structure for announcement -- ---------------------------- DROP TABLE IF EXISTS `announcement`; CREATE TABLE `announcement` ( `id` bigint UNSIGNED NOT NULL AUTO_INCREMENT, `title` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL, `content` text CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL, `enabled` tinyint(1) NOT NULL DEFAULT 1, `jump_url` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL, `created_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3), `updated_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3) ON UPDATE CURRENT_TIMESTAMP(3), PRIMARY KEY (`id`) USING BTREE ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic; -- ---------------------------- -- Table structure for link_batch -- ---------------------------- DROP TABLE IF EXISTS `link_batch`; CREATE TABLE `link_batch` ( `id` bigint UNSIGNED NOT NULL AUTO_INCREMENT, `agent_id` bigint UNSIGNED NOT NULL, `quantity` int UNSIGNED NOT NULL, `times` int UNSIGNED NOT NULL, `batch_size` int UNSIGNED NOT NULL, `deduct_points` bigint UNSIGNED NOT NULL, `operator_id` bigint UNSIGNED NULL DEFAULT NULL, `created_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3), PRIMARY KEY (`id`) USING BTREE, INDEX `idx_lb_agent_time`(`agent_id` ASC, `created_at` ASC) USING BTREE, INDEX `fk_lb_operator`(`operator_id` ASC) USING BTREE, CONSTRAINT `fk_lb_agent` FOREIGN KEY (`agent_id`) REFERENCES `user_account` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT `fk_lb_operator` FOREIGN KEY (`operator_id`) REFERENCES `user_account` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT `chk_lb_batch_pos` CHECK (`batch_size` > 0), CONSTRAINT `chk_lb_quantity_pos` CHECK (`quantity` > 0), CONSTRAINT `chk_lb_times_pos` CHECK (`times` > 0) ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic; -- ---------------------------- -- Table structure for link_task -- ---------------------------- DROP TABLE IF EXISTS `link_task`; CREATE TABLE `link_task` ( `id` bigint UNSIGNED NOT NULL AUTO_INCREMENT, `batch_id` bigint UNSIGNED NOT NULL, `agent_id` bigint UNSIGNED NOT NULL, `code_no` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL, `token_hash` char(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL, `expire_at` datetime(3) NOT NULL, `status` enum('NEW','USING','LOGGED_IN','REFUNDED','EXPIRED') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL DEFAULT 'NEW', `region` enum('Q','V') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL, `machine_id` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL, `login_at` datetime(3) NULL DEFAULT NULL, `refund_at` datetime(3) NULL DEFAULT NULL, `revoked_at` datetime(3) NULL DEFAULT NULL, `created_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3), `updated_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3) ON UPDATE CURRENT_TIMESTAMP(3), PRIMARY KEY (`id`) USING BTREE, UNIQUE INDEX `uk_code_no`(`code_no` ASC) USING BTREE, UNIQUE INDEX `uk_token_hash`(`token_hash` ASC) USING BTREE, INDEX `idx_agent_status`(`agent_id` ASC, `status` ASC) USING BTREE, INDEX `idx_expire_at`(`expire_at` ASC) USING BTREE, INDEX `idx_created_at`(`created_at` ASC) USING BTREE, INDEX `fk_lt_batch`(`batch_id` ASC) USING BTREE, CONSTRAINT `fk_lt_agent` FOREIGN KEY (`agent_id`) REFERENCES `user_account` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT, CONSTRAINT `fk_lt_batch` FOREIGN KEY (`batch_id`) REFERENCES `link_batch` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic; -- ---------------------------- -- Table structure for operation_log -- ---------------------------- DROP TABLE IF EXISTS `operation_log`; CREATE TABLE `operation_log` ( `id` bigint UNSIGNED NOT NULL AUTO_INCREMENT, `actor_type` enum('admin','agent','system','user') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL, `actor_id` bigint UNSIGNED NULL DEFAULT NULL, `code_no` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL, `op` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL, `detail` json NULL, `client_ip` varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL, `user_agent` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL, `created_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3), PRIMARY KEY (`id`) USING BTREE, INDEX `idx_log_code_time`(`code_no` ASC, `created_at` ASC) USING BTREE, INDEX `idx_log_time`(`created_at` ASC) USING BTREE ) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic; -- ---------------------------- -- Table structure for user_account -- ---------------------------- DROP TABLE IF EXISTS `user_account`; CREATE TABLE `user_account` ( `id` bigint UNSIGNED NOT NULL AUTO_INCREMENT, `user_type` enum('ADMIN','AGENT') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL, `username` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL, `password_hash` varchar(120) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL, `status` enum('ENABLED','DISABLED') CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL DEFAULT 'ENABLED', `points_balance` bigint UNSIGNED NOT NULL DEFAULT 0, `created_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3), `updated_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3) ON UPDATE CURRENT_TIMESTAMP(3), PRIMARY KEY (`id`) USING BTREE, UNIQUE INDEX `username`(`username` ASC) USING BTREE, CONSTRAINT `chk_points_nonneg` CHECK (`points_balance` >= 0) ) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic; -- ---------------------------- -- Table structure for system_config -- ---------------------------- DROP TABLE IF EXISTS `system_config`; CREATE TABLE `system_config` ( `id` bigint UNSIGNED NOT NULL AUTO_INCREMENT, `config_key` varchar(100) NOT NULL COMMENT '配置键', `config_value` text NOT NULL COMMENT '配置值', `config_type` varchar(50) NOT NULL DEFAULT 'STRING' COMMENT '配置类型:STRING, INTEGER, BOOLEAN, JSON', `description` varchar(500) NULL DEFAULT NULL COMMENT '配置描述', `is_system` tinyint(1) NOT NULL DEFAULT 0 COMMENT '是否系统配置(1是,0否)', `created_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3), `updated_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3) ON UPDATE CURRENT_TIMESTAMP(3), PRIMARY KEY (`id`) USING BTREE, UNIQUE INDEX `uk_config_key`(`config_key` ASC) USING BTREE, INDEX `idx_config_type`(`config_type` ASC) USING BTREE ) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic; -- 插入默认配置 INSERT INTO `system_config` (`config_key`, `config_value`, `config_type`, `description`, `is_system`) VALUES ('link.default_quantity', '50', 'INTEGER', '链接生成默认奖励点数', 1), ('link.refresh_interval', '300', 'INTEGER', '链接刷新间隔(秒)', 1), ('link.qr_expire_time', '600', 'INTEGER', '二维码过期时间(秒)', 1), ('link.max_times_per_batch', '100', 'INTEGER', '每批次最大刷奖励次数', 1), ('link.min_quantity', '10', 'INTEGER', '最小奖励点数', 1), ('link.max_quantity', '1000', 'INTEGER', '最大奖励点数', 1), ('script.server_url', 'http://36.138.184.60:12345', 'STRING', '脚本服务器地址', 1), ('script.qr_path_template', '/{machineId}/二维码.png', 'STRING', '二维码图片路径模板', 1); SET FOREIGN_KEY_CHECKS = 1;