160 lines
8.8 KiB
SQL
160 lines
8.8 KiB
SQL
-- =============================================
|
|
-- 武术赛事赛程编排系统 - 数据库表创建脚本(带数据库选择)
|
|
-- =============================================
|
|
-- 创建日期: 2025-12-09
|
|
-- 版本: v1.1
|
|
-- 说明: 自动选择正确的数据库并创建赛程编排相关的4张核心表
|
|
-- =============================================
|
|
|
|
-- 选择数据库(根据实际情况修改)
|
|
USE martial_db;
|
|
|
|
-- 检查表是否已存在,如果存在则删除(可选,生产环境请注释掉)
|
|
-- DROP TABLE IF EXISTS martial_schedule_participant;
|
|
-- DROP TABLE IF EXISTS martial_schedule_detail;
|
|
-- DROP TABLE IF EXISTS martial_schedule_group;
|
|
-- DROP TABLE IF EXISTS martial_schedule_status;
|
|
|
|
-- 1. 赛程编排分组表
|
|
CREATE TABLE IF NOT EXISTS `martial_schedule_group` (
|
|
`id` bigint(0) NOT NULL COMMENT '主键ID',
|
|
`competition_id` bigint(0) NOT NULL COMMENT '赛事ID',
|
|
`group_name` varchar(200) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '分组名称(如:太极拳男组)',
|
|
`project_id` bigint(0) NOT NULL COMMENT '项目ID',
|
|
`project_name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '项目名称',
|
|
`category` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '组别(成年组、少年组等)',
|
|
`project_type` tinyint(1) NOT NULL DEFAULT 1 COMMENT '项目类型(1=个人 2=集体)',
|
|
`display_order` int(0) NOT NULL DEFAULT 0 COMMENT '显示顺序(集体项目优先,数字越小越靠前)',
|
|
`total_participants` int(0) NULL DEFAULT 0 COMMENT '总参赛人数',
|
|
`total_teams` int(0) NULL DEFAULT 0 COMMENT '总队伍数(仅集体项目)',
|
|
`estimated_duration` int(0) NULL DEFAULT 0 COMMENT '预计时长(分钟)',
|
|
`create_user` bigint(0) NULL DEFAULT NULL,
|
|
`create_dept` bigint(0) NULL DEFAULT NULL,
|
|
`create_time` datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0),
|
|
`update_user` bigint(0) NULL DEFAULT NULL,
|
|
`update_time` datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0),
|
|
`status` int(0) NULL DEFAULT 1 COMMENT '状态(1-启用,2-禁用)',
|
|
`is_deleted` int(0) NULL DEFAULT 0,
|
|
`tenant_id` varchar(12) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT '000000',
|
|
PRIMARY KEY (`id`) USING BTREE,
|
|
INDEX `idx_competition` (`competition_id`) USING BTREE,
|
|
INDEX `idx_project` (`project_id`) USING BTREE,
|
|
INDEX `idx_display_order` (`display_order`) USING BTREE,
|
|
INDEX `idx_tenant` (`tenant_id`) USING BTREE
|
|
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '赛程编排分组表' ROW_FORMAT = Dynamic;
|
|
|
|
-- 2. 赛程编排明细表(场地时间段分配)
|
|
CREATE TABLE IF NOT EXISTS `martial_schedule_detail` (
|
|
`id` bigint(0) NOT NULL COMMENT '主键ID',
|
|
`schedule_group_id` bigint(0) NOT NULL COMMENT '分组ID',
|
|
`competition_id` bigint(0) NOT NULL COMMENT '赛事ID',
|
|
`venue_id` bigint(0) NOT NULL COMMENT '场地ID',
|
|
`venue_name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '场地名称',
|
|
`schedule_date` date NOT NULL COMMENT '比赛日期',
|
|
`time_period` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '时间段(morning/afternoon)',
|
|
`time_slot` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '时间点(08:30/13:30)',
|
|
`estimated_start_time` datetime(0) NULL DEFAULT NULL COMMENT '预计开始时间',
|
|
`estimated_end_time` datetime(0) NULL DEFAULT NULL COMMENT '预计结束时间',
|
|
`estimated_duration` int(0) NULL DEFAULT 0 COMMENT '预计时长(分钟)',
|
|
`participant_count` int(0) NULL DEFAULT 0 COMMENT '参赛人数',
|
|
`sort_order` int(0) NULL DEFAULT 0 COMMENT '场内顺序',
|
|
`create_user` bigint(0) NULL DEFAULT NULL,
|
|
`create_dept` bigint(0) NULL DEFAULT NULL,
|
|
`create_time` datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0),
|
|
`update_user` bigint(0) NULL DEFAULT NULL,
|
|
`update_time` datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0),
|
|
`status` int(0) NULL DEFAULT 1 COMMENT '状态(1-未开始,2-进行中,3-已完成)',
|
|
`is_deleted` int(0) NULL DEFAULT 0,
|
|
`tenant_id` varchar(12) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT '000000',
|
|
PRIMARY KEY (`id`) USING BTREE,
|
|
INDEX `idx_group` (`schedule_group_id`) USING BTREE,
|
|
INDEX `idx_competition` (`competition_id`) USING BTREE,
|
|
INDEX `idx_venue_time` (`venue_id`, `schedule_date`, `time_slot`) USING BTREE,
|
|
INDEX `idx_tenant` (`tenant_id`) USING BTREE
|
|
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '赛程编排明细表(场地时间段分配)' ROW_FORMAT = Dynamic;
|
|
|
|
-- 3. 赛程编排参赛者关联表
|
|
CREATE TABLE IF NOT EXISTS `martial_schedule_participant` (
|
|
`id` bigint(0) NOT NULL COMMENT '主键ID',
|
|
`schedule_detail_id` bigint(0) NOT NULL COMMENT '编排明细ID',
|
|
`schedule_group_id` bigint(0) NOT NULL COMMENT '分组ID',
|
|
`participant_id` bigint(0) NOT NULL COMMENT '参赛者ID(关联martial_athlete表)',
|
|
`organization` varchar(200) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '单位名称',
|
|
`player_name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '选手姓名',
|
|
`project_name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '项目名称',
|
|
`category` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '组别',
|
|
`performance_order` int(0) NULL DEFAULT 0 COMMENT '出场顺序',
|
|
`create_user` bigint(0) NULL DEFAULT NULL,
|
|
`create_dept` bigint(0) NULL DEFAULT NULL,
|
|
`create_time` datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0),
|
|
`update_user` bigint(0) NULL DEFAULT NULL,
|
|
`update_time` datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0),
|
|
`status` int(0) NULL DEFAULT 1 COMMENT '状态(1-待出场,2-已出场)',
|
|
`is_deleted` int(0) NULL DEFAULT 0,
|
|
`tenant_id` varchar(12) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT '000000',
|
|
PRIMARY KEY (`id`) USING BTREE,
|
|
INDEX `idx_detail` (`schedule_detail_id`) USING BTREE,
|
|
INDEX `idx_group` (`schedule_group_id`) USING BTREE,
|
|
INDEX `idx_participant` (`participant_id`) USING BTREE,
|
|
INDEX `idx_tenant` (`tenant_id`) USING BTREE
|
|
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '赛程编排参赛者关联表' ROW_FORMAT = Dynamic;
|
|
|
|
-- 4. 赛程编排状态表
|
|
CREATE TABLE IF NOT EXISTS `martial_schedule_status` (
|
|
`id` bigint(0) NOT NULL COMMENT '主键ID',
|
|
`competition_id` bigint(0) NOT NULL COMMENT '赛事ID(唯一)',
|
|
`schedule_status` tinyint(1) NOT NULL DEFAULT 0 COMMENT '编排状态(0=未编排 1=编排中 2=已保存锁定)',
|
|
`last_auto_schedule_time` datetime(0) NULL DEFAULT NULL COMMENT '最后自动编排时间',
|
|
`locked_time` datetime(0) NULL DEFAULT NULL COMMENT '锁定时间',
|
|
`locked_by` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '锁定人',
|
|
`total_groups` int(0) NULL DEFAULT 0 COMMENT '总分组数',
|
|
`total_participants` int(0) NULL DEFAULT 0 COMMENT '总参赛人数',
|
|
`create_user` bigint(0) NULL DEFAULT NULL,
|
|
`create_dept` bigint(0) NULL DEFAULT NULL,
|
|
`create_time` datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0),
|
|
`update_user` bigint(0) NULL DEFAULT NULL,
|
|
`update_time` datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0),
|
|
`status` int(0) NULL DEFAULT 1 COMMENT '状态(1-启用,2-禁用)',
|
|
`is_deleted` int(0) NULL DEFAULT 0,
|
|
`tenant_id` varchar(12) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT '000000',
|
|
PRIMARY KEY (`id`) USING BTREE,
|
|
UNIQUE INDEX `uk_competition` (`competition_id`) USING BTREE,
|
|
INDEX `idx_tenant` (`tenant_id`) USING BTREE,
|
|
INDEX `idx_schedule_status` (`schedule_status`) USING BTREE
|
|
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '赛程编排状态表' ROW_FORMAT = Dynamic;
|
|
|
|
-- 验证表是否创建成功
|
|
SELECT
|
|
'表创建完成' AS message,
|
|
COUNT(*) AS table_count
|
|
FROM information_schema.tables
|
|
WHERE table_schema = 'martial_db'
|
|
AND table_name IN (
|
|
'martial_schedule_group',
|
|
'martial_schedule_detail',
|
|
'martial_schedule_participant',
|
|
'martial_schedule_status'
|
|
);
|
|
|
|
-- =============================================
|
|
-- 使用说明
|
|
-- =============================================
|
|
--
|
|
-- 1. 确认数据库名称
|
|
-- 如果你的数据库名称不是 martial_db,请修改第9行的 USE 语句
|
|
--
|
|
-- 2. 执行脚本
|
|
-- 方式1: 在MySQL客户端中直接执行
|
|
-- mysql -u root -p < deploy_schedule_tables.sql
|
|
--
|
|
-- 方式2: 在数据库管理工具中执行(Navicat/DBeaver等)
|
|
--
|
|
-- 3. 验证
|
|
-- 执行完成后应该看到 "table_count = 4" 的结果
|
|
--
|
|
-- 4. 下一步
|
|
-- 执行测试数据导入脚本:
|
|
-- mysql -u root -p martial_db < martial-web/test-data/create_100_team_participants.sql
|
|
--
|
|
-- =============================================
|