509 lines
30 KiB
SQL
509 lines
30 KiB
SQL
-- ========================================
|
||
-- 心理测评系统扩展表结构设计
|
||
-- 创建时间: 2025-11-01
|
||
-- ========================================
|
||
|
||
SET NAMES utf8mb4;
|
||
SET FOREIGN_KEY_CHECKS = 0;
|
||
|
||
-- ----------------------------
|
||
-- 1、用户档案扩展表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_user_profile`;
|
||
CREATE TABLE `psy_user_profile` (
|
||
`profile_id` bigint NOT NULL AUTO_INCREMENT COMMENT '档案ID',
|
||
`user_id` bigint NOT NULL COMMENT '用户ID(关联sys_user)',
|
||
`profile_type` varchar(50) DEFAULT 'standard' COMMENT '档案类型(如:standard标准 child儿童 adult成人 senior老年)',
|
||
`profile_data` longtext COMMENT '档案数据(JSON格式,支持自定义字段)',
|
||
`avatar` varchar(500) DEFAULT NULL COMMENT '头像',
|
||
`id_card` varchar(18) DEFAULT NULL COMMENT '身份证号',
|
||
`birthday` date DEFAULT NULL COMMENT '生日',
|
||
`education` varchar(50) DEFAULT NULL COMMENT '学历',
|
||
`occupation` varchar(100) DEFAULT NULL COMMENT '职业',
|
||
`address` varchar(500) DEFAULT NULL COMMENT '地址',
|
||
`emergency_contact` varchar(50) DEFAULT NULL COMMENT '紧急联系人',
|
||
`emergency_phone` varchar(11) DEFAULT NULL COMMENT '紧急联系电话',
|
||
`medical_history` text COMMENT '病史',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
`remark` varchar(500) DEFAULT NULL COMMENT '备注',
|
||
PRIMARY KEY (`profile_id`),
|
||
UNIQUE KEY `uk_user_id` (`user_id`),
|
||
KEY `idx_profile_type` (`profile_type`),
|
||
CONSTRAINT `fk_profile_user` FOREIGN KEY (`user_id`) REFERENCES `sys_user` (`user_id`) ON DELETE CASCADE
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='用户档案扩展表';
|
||
|
||
-- ----------------------------
|
||
-- 2、量表权限表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_scale_permission`;
|
||
CREATE TABLE `psy_scale_permission` (
|
||
`permission_id` bigint NOT NULL AUTO_INCREMENT COMMENT '权限ID',
|
||
`scale_id` bigint NOT NULL COMMENT '量表ID',
|
||
`dept_id` bigint DEFAULT NULL COMMENT '部门ID(关联sys_dept,为空表示所有部门)',
|
||
`role_id` bigint DEFAULT NULL COMMENT '角色ID(关联sys_role,为空表示所有角色)',
|
||
`user_id` bigint DEFAULT NULL COMMENT '用户ID(关联sys_user,为空表示所有用户)',
|
||
`class_name` varchar(100) DEFAULT NULL COMMENT '班级名称(特殊字段,用于罪犯管理)',
|
||
`start_time` datetime DEFAULT NULL COMMENT '开始时间',
|
||
`end_time` datetime DEFAULT NULL COMMENT '结束时间',
|
||
`status` char(1) DEFAULT '0' COMMENT '状态(0有效 1无效)',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
`remark` varchar(500) DEFAULT NULL COMMENT '备注',
|
||
PRIMARY KEY (`permission_id`),
|
||
KEY `idx_scale_id` (`scale_id`),
|
||
KEY `idx_dept_id` (`dept_id`),
|
||
KEY `idx_role_id` (`role_id`),
|
||
KEY `idx_user_id` (`user_id`),
|
||
KEY `idx_status` (`status`),
|
||
CONSTRAINT `fk_permission_scale` FOREIGN KEY (`scale_id`) REFERENCES `psy_scale` (`scale_id`) ON DELETE CASCADE,
|
||
CONSTRAINT `fk_permission_dept` FOREIGN KEY (`dept_id`) REFERENCES `sys_dept` (`dept_id`) ON DELETE CASCADE,
|
||
CONSTRAINT `fk_permission_role` FOREIGN KEY (`role_id`) REFERENCES `sys_role` (`role_id`) ON DELETE CASCADE,
|
||
CONSTRAINT `fk_permission_user` FOREIGN KEY (`user_id`) REFERENCES `sys_user` (`user_id`) ON DELETE CASCADE
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='量表权限表';
|
||
|
||
-- ----------------------------
|
||
-- 3、自定义问卷表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_questionnaire`;
|
||
CREATE TABLE `psy_questionnaire` (
|
||
`questionnaire_id` bigint NOT NULL AUTO_INCREMENT COMMENT '问卷ID',
|
||
`questionnaire_code` varchar(50) NOT NULL COMMENT '问卷编码',
|
||
`questionnaire_name` varchar(100) NOT NULL COMMENT '问卷名称',
|
||
`questionnaire_type` varchar(50) DEFAULT 'custom' COMMENT '问卷类型(custom自定义 exam考试 practice练习)',
|
||
`paper_type` varchar(50) DEFAULT 'manual' COMMENT '组卷方式(manual手动 random随机 mixed混合)',
|
||
`item_count` int DEFAULT 0 COMMENT '题目数量',
|
||
`total_score` decimal(10,2) DEFAULT 0.00 COMMENT '总分',
|
||
`pass_score` decimal(10,2) DEFAULT NULL COMMENT '及格分数',
|
||
`estimated_time` int DEFAULT NULL COMMENT '预计完成时间(分钟)',
|
||
`description` text COMMENT '问卷描述',
|
||
`status` char(1) DEFAULT '0' COMMENT '状态(0正常 1停用)',
|
||
`sort_order` int DEFAULT 0 COMMENT '排序顺序',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
`remark` varchar(500) DEFAULT NULL COMMENT '备注',
|
||
PRIMARY KEY (`questionnaire_id`),
|
||
UNIQUE KEY `uk_questionnaire_code` (`questionnaire_code`),
|
||
KEY `idx_questionnaire_type` (`questionnaire_type`),
|
||
KEY `idx_status` (`status`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='自定义问卷表';
|
||
|
||
-- ----------------------------
|
||
-- 4、问卷题目表(支持多种题型)
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_questionnaire_item`;
|
||
CREATE TABLE `psy_questionnaire_item` (
|
||
`item_id` bigint NOT NULL AUTO_INCREMENT COMMENT '题目ID',
|
||
`questionnaire_id` bigint NOT NULL COMMENT '问卷ID',
|
||
`item_number` int NOT NULL COMMENT '题目序号',
|
||
`item_content` text NOT NULL COMMENT '题目内容',
|
||
`item_type` varchar(20) NOT NULL COMMENT '题目类型(radio单选 checkbox多选 boolean判断 input填空 sort排序 calculate计算 text简答 textarea问答 essay作文)',
|
||
`is_required` char(1) DEFAULT '1' COMMENT '是否必填(0否 1是)',
|
||
`score` decimal(10,2) DEFAULT 0.00 COMMENT '题目分值',
|
||
`sort_order` int DEFAULT 0 COMMENT '排序顺序',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
`remark` varchar(500) DEFAULT NULL COMMENT '备注',
|
||
PRIMARY KEY (`item_id`),
|
||
KEY `idx_questionnaire_id` (`questionnaire_id`),
|
||
KEY `idx_item_number` (`questionnaire_id`, `item_number`),
|
||
CONSTRAINT `fk_q_item_questionnaire` FOREIGN KEY (`questionnaire_id`) REFERENCES `psy_questionnaire` (`questionnaire_id`) ON DELETE CASCADE
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='问卷题目表';
|
||
|
||
-- ----------------------------
|
||
-- 5、问卷选项表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_questionnaire_option`;
|
||
CREATE TABLE `psy_questionnaire_option` (
|
||
`option_id` bigint NOT NULL AUTO_INCREMENT COMMENT '选项ID',
|
||
`item_id` bigint NOT NULL COMMENT '题目ID',
|
||
`option_code` varchar(20) DEFAULT NULL COMMENT '选项编码(如A、B、C或1、2、3)',
|
||
`option_content` varchar(500) NOT NULL COMMENT '选项内容',
|
||
`option_score` decimal(10,2) DEFAULT 0.00 COMMENT '选项分值',
|
||
`is_correct` char(1) DEFAULT '0' COMMENT '是否正确答案(0否 1是)',
|
||
`sort_order` int DEFAULT 0 COMMENT '排序顺序',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
PRIMARY KEY (`option_id`),
|
||
KEY `idx_item_id` (`item_id`),
|
||
CONSTRAINT `fk_q_option_item` FOREIGN KEY (`item_id`) REFERENCES `psy_questionnaire_item` (`item_id`) ON DELETE CASCADE
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='问卷选项表';
|
||
|
||
-- ----------------------------
|
||
-- 6、问卷答题记录表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_questionnaire_answer`;
|
||
CREATE TABLE `psy_questionnaire_answer` (
|
||
`answer_id` bigint NOT NULL AUTO_INCREMENT COMMENT '答案ID',
|
||
`questionnaire_id` bigint NOT NULL COMMENT '问卷ID',
|
||
`user_id` bigint DEFAULT NULL COMMENT '用户ID(关联sys_user)',
|
||
`respondent_name` varchar(50) DEFAULT NULL COMMENT '答题人姓名',
|
||
`start_time` datetime DEFAULT NULL COMMENT '开始时间',
|
||
`submit_time` datetime DEFAULT NULL COMMENT '提交时间',
|
||
`total_score` decimal(10,2) DEFAULT 0.00 COMMENT '总得分',
|
||
`is_pass` char(1) DEFAULT '0' COMMENT '是否及格(0否 1是)',
|
||
`rank` int DEFAULT NULL COMMENT '排名',
|
||
`status` char(1) DEFAULT '0' COMMENT '状态(0进行中 1已完成 2已作废)',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
PRIMARY KEY (`answer_id`),
|
||
KEY `idx_questionnaire_id` (`questionnaire_id`),
|
||
KEY `idx_user_id` (`user_id`),
|
||
KEY `idx_status` (`status`),
|
||
CONSTRAINT `fk_q_answer_questionnaire` FOREIGN KEY (`questionnaire_id`) REFERENCES `psy_questionnaire` (`questionnaire_id`),
|
||
CONSTRAINT `fk_q_answer_user` FOREIGN KEY (`user_id`) REFERENCES `sys_user` (`user_id`) ON DELETE SET NULL
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='问卷答题记录表';
|
||
|
||
-- ----------------------------
|
||
-- 7、语音读题配置表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_voice_config`;
|
||
CREATE TABLE `psy_voice_config` (
|
||
`config_id` bigint NOT NULL AUTO_INCREMENT COMMENT '配置ID',
|
||
`item_id` bigint DEFAULT NULL COMMENT '题目ID(为空表示全局配置)',
|
||
`voice_type` varchar(50) DEFAULT 'tts' COMMENT '语音类型(tts合成 human真人录音)',
|
||
`voice_url` varchar(500) DEFAULT NULL COMMENT '语音文件URL',
|
||
`voice_provider` varchar(50) DEFAULT NULL COMMENT 'TTS提供商(aliyun tencent baidu local)',
|
||
`voice_speed` decimal(3,2) DEFAULT 1.00 COMMENT '语速(0.5-2.0)',
|
||
`voice_pitch` decimal(3,2) DEFAULT 1.00 COMMENT '音调(0.5-2.0)',
|
||
`status` char(1) DEFAULT '0' COMMENT '状态(0正常 1停用)',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
`remark` varchar(500) DEFAULT NULL COMMENT '备注',
|
||
PRIMARY KEY (`config_id`),
|
||
KEY `idx_item_id` (`item_id`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='语音读题配置表';
|
||
|
||
-- ----------------------------
|
||
-- 8、危机预警表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_warning`;
|
||
CREATE TABLE `psy_warning` (
|
||
`warning_id` bigint NOT NULL AUTO_INCREMENT COMMENT '预警ID',
|
||
`assessment_id` bigint NOT NULL COMMENT '测评ID',
|
||
`user_id` bigint DEFAULT NULL COMMENT '用户ID',
|
||
`scale_id` bigint NOT NULL COMMENT '量表ID',
|
||
`factor_id` bigint DEFAULT NULL COMMENT '因子ID(为空表示整体预警)',
|
||
`warning_type` varchar(50) DEFAULT 'score' COMMENT '预警类型(score分数 risk风险)',
|
||
`warning_level` varchar(50) DEFAULT 'medium' COMMENT '预警级别(low低 medium中 high高 critical严重)',
|
||
`warning_score` decimal(10,2) DEFAULT NULL COMMENT '预警分值',
|
||
`warning_reason` text COMMENT '预警原因',
|
||
`status` char(1) DEFAULT '0' COMMENT '状态(0待处理 1处理中 2已解除 3已归档)',
|
||
`handler_id` bigint DEFAULT NULL COMMENT '处理人ID',
|
||
`handle_time` datetime DEFAULT NULL COMMENT '处理时间',
|
||
`handle_result` text COMMENT '处理结果',
|
||
`relief_time` datetime DEFAULT NULL COMMENT '解除时间',
|
||
`relief_reason` text COMMENT '解除原因',
|
||
`notification_sent` char(1) DEFAULT '0' COMMENT '是否已通知(0否 1是)',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
`remark` varchar(500) DEFAULT NULL COMMENT '备注',
|
||
PRIMARY KEY (`warning_id`),
|
||
KEY `idx_assessment_id` (`assessment_id`),
|
||
KEY `idx_user_id` (`user_id`),
|
||
KEY `idx_status` (`status`),
|
||
KEY `idx_warning_level` (`warning_level`),
|
||
CONSTRAINT `fk_warning_assessment` FOREIGN KEY (`assessment_id`) REFERENCES `psy_assessment` (`assessment_id`),
|
||
CONSTRAINT `fk_warning_user` FOREIGN KEY (`user_id`) REFERENCES `sys_user` (`user_id`) ON DELETE SET NULL,
|
||
CONSTRAINT `fk_warning_scale` FOREIGN KEY (`scale_id`) REFERENCES `psy_scale` (`scale_id`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='危机预警表';
|
||
|
||
-- ----------------------------
|
||
-- 9、预警规则配置表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_warning_rule`;
|
||
CREATE TABLE `psy_warning_rule` (
|
||
`rule_id` bigint NOT NULL AUTO_INCREMENT COMMENT '规则ID',
|
||
`scale_id` bigint NOT NULL COMMENT '量表ID',
|
||
`factor_id` bigint DEFAULT NULL COMMENT '因子ID(为空表示整体规则)',
|
||
`rule_name` varchar(100) NOT NULL COMMENT '规则名称',
|
||
`warning_level` varchar(50) DEFAULT 'medium' COMMENT '预警级别',
|
||
`score_min` decimal(10,2) DEFAULT NULL COMMENT '分值最小值',
|
||
`score_max` decimal(10,2) DEFAULT NULL COMMENT '分值最大值',
|
||
`percentile_min` decimal(5,2) DEFAULT NULL COMMENT '百分位最小值',
|
||
`percentile_max` decimal(5,2) DEFAULT NULL COMMENT '百分位最大值',
|
||
`auto_relief` char(1) DEFAULT '0' COMMENT '是否自动解除(0否 1是)',
|
||
`relief_condition` text COMMENT '解除条件(JSON格式)',
|
||
`status` char(1) DEFAULT '0' COMMENT '状态(0启用 1禁用)',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
`remark` varchar(500) DEFAULT NULL COMMENT '备注',
|
||
PRIMARY KEY (`rule_id`),
|
||
KEY `idx_scale_id` (`scale_id`),
|
||
KEY `idx_factor_id` (`factor_id`),
|
||
KEY `idx_status` (`status`),
|
||
CONSTRAINT `fk_warning_rule_scale` FOREIGN KEY (`scale_id`) REFERENCES `psy_scale` (`scale_id`) ON DELETE CASCADE,
|
||
CONSTRAINT `fk_warning_rule_factor` FOREIGN KEY (`factor_id`) REFERENCES `psy_factor` (`factor_id`) ON DELETE CASCADE
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='预警规则配置表';
|
||
|
||
-- ----------------------------
|
||
-- 10、二维码管理表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_qrcode`;
|
||
CREATE TABLE `psy_qrcode` (
|
||
`qrcode_id` bigint NOT NULL AUTO_INCREMENT COMMENT '二维码ID',
|
||
`qrcode_code` varchar(50) NOT NULL COMMENT '二维码编号',
|
||
`qrcode_type` varchar(50) NOT NULL COMMENT '二维码类型(test测评 view_report查看报告 register注册 login登录)',
|
||
`target_type` varchar(50) DEFAULT NULL COMMENT '目标类型(scale量表 assessment测评 report报告)',
|
||
`target_id` bigint DEFAULT NULL COMMENT '目标ID',
|
||
`short_url` varchar(200) DEFAULT NULL COMMENT '短链接',
|
||
`qrcode_url` varchar(500) DEFAULT NULL COMMENT '二维码图片URL',
|
||
`scan_count` int DEFAULT 0 COMMENT '扫码次数',
|
||
`expire_time` datetime DEFAULT NULL COMMENT '过期时间',
|
||
`status` char(1) DEFAULT '0' COMMENT '状态(0有效 1无效 2已过期)',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
`remark` varchar(500) DEFAULT NULL COMMENT '备注',
|
||
PRIMARY KEY (`qrcode_id`),
|
||
UNIQUE KEY `uk_qrcode_code` (`qrcode_code`),
|
||
KEY `idx_qrcode_type` (`qrcode_type`),
|
||
KEY `idx_status` (`status`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='二维码管理表';
|
||
|
||
-- ----------------------------
|
||
-- 11、二维码扫码记录表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_qrcode_log`;
|
||
CREATE TABLE `psy_qrcode_log` (
|
||
`log_id` bigint NOT NULL AUTO_INCREMENT COMMENT '记录ID',
|
||
`qrcode_id` bigint NOT NULL COMMENT '二维码ID',
|
||
`user_id` bigint DEFAULT NULL COMMENT '扫码用户ID',
|
||
`ip_address` varchar(128) DEFAULT '' COMMENT 'IP地址',
|
||
`user_agent` varchar(500) DEFAULT NULL COMMENT '用户代理',
|
||
`scan_time` datetime DEFAULT NULL COMMENT '扫码时间',
|
||
PRIMARY KEY (`log_id`),
|
||
KEY `idx_qrcode_id` (`qrcode_id`),
|
||
KEY `idx_scan_time` (`scan_time`),
|
||
CONSTRAINT `fk_qrcode_log_qrcode` FOREIGN KEY (`qrcode_id`) REFERENCES `psy_qrcode` (`qrcode_id`) ON DELETE CASCADE
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='二维码扫码记录表';
|
||
|
||
-- ----------------------------
|
||
-- 12、数据备份表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `sys_backup`;
|
||
CREATE TABLE `sys_backup` (
|
||
`backup_id` bigint NOT NULL AUTO_INCREMENT COMMENT '备份ID',
|
||
`backup_name` varchar(200) NOT NULL COMMENT '备份名称',
|
||
`backup_type` varchar(50) DEFAULT 'full' COMMENT '备份类型(full全量 incremental增量)',
|
||
`backup_path` varchar(500) NOT NULL COMMENT '备份路径',
|
||
`file_size` bigint DEFAULT NULL COMMENT '文件大小(字节)',
|
||
`backup_status` char(1) DEFAULT '0' COMMENT '备份状态(0备份中 1成功 2失败)',
|
||
`backup_time` datetime DEFAULT NULL COMMENT '备份时间',
|
||
`backup_duration` int DEFAULT NULL COMMENT '备份耗时(秒)',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`remark` varchar(500) DEFAULT NULL COMMENT '备注',
|
||
PRIMARY KEY (`backup_id`),
|
||
KEY `idx_backup_time` (`backup_time`),
|
||
KEY `idx_backup_status` (`backup_status`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='数据备份表';
|
||
|
||
-- ----------------------------
|
||
-- 13、心理网站内容表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_website_content`;
|
||
CREATE TABLE `psy_website_content` (
|
||
`content_id` bigint NOT NULL AUTO_INCREMENT COMMENT '内容ID',
|
||
`content_type` varchar(50) NOT NULL COMMENT '内容类型(article文章 notice公告 banner横幅 link链接)',
|
||
`category_id` bigint DEFAULT NULL COMMENT '分类ID',
|
||
`title` varchar(200) NOT NULL COMMENT '标题',
|
||
`subtitle` varchar(200) DEFAULT NULL COMMENT '副标题',
|
||
`summary` varchar(500) DEFAULT NULL COMMENT '摘要',
|
||
`content` longtext COMMENT '正文内容',
|
||
`cover_image` varchar(500) DEFAULT NULL COMMENT '封面图片',
|
||
`author` varchar(100) DEFAULT NULL COMMENT '作者',
|
||
`source` varchar(200) DEFAULT NULL COMMENT '来源',
|
||
`click_count` int DEFAULT 0 COMMENT '点击量',
|
||
`like_count` int DEFAULT 0 COMMENT '点赞数',
|
||
`is_top` char(1) DEFAULT '0' COMMENT '是否置顶(0否 1是)',
|
||
`is_recommend` char(1) DEFAULT '0' COMMENT '是否推荐(0否 1是)',
|
||
`publish_time` datetime DEFAULT NULL COMMENT '发布时间',
|
||
`sort_order` int DEFAULT 0 COMMENT '排序顺序',
|
||
`status` char(1) DEFAULT '0' COMMENT '状态(0草稿 1已发布 2已下架)',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
`remark` varchar(500) DEFAULT NULL COMMENT '备注',
|
||
PRIMARY KEY (`content_id`),
|
||
KEY `idx_content_type` (`content_type`),
|
||
KEY `idx_status` (`status`),
|
||
KEY `idx_publish_time` (`publish_time`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='心理网站内容表';
|
||
|
||
-- ----------------------------
|
||
-- 14、心理网站配置表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `psy_website_config`;
|
||
CREATE TABLE `psy_website_config` (
|
||
`config_id` bigint NOT NULL AUTO_INCREMENT COMMENT '配置ID',
|
||
`config_key` varchar(100) NOT NULL COMMENT '配置键',
|
||
`config_value` text COMMENT '配置值',
|
||
`config_type` varchar(50) DEFAULT 'text' COMMENT '配置类型(text文本 number数字 jsonJSON image图片)',
|
||
`config_description` varchar(500) DEFAULT NULL COMMENT '配置描述',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
PRIMARY KEY (`config_id`),
|
||
UNIQUE KEY `uk_config_key` (`config_key`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='心理网站配置表';
|
||
|
||
-- ----------------------------
|
||
-- 15、开放式API配置表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `sys_api_config`;
|
||
CREATE TABLE `sys_api_config` (
|
||
`config_id` bigint NOT NULL AUTO_INCREMENT COMMENT '配置ID',
|
||
`api_name` varchar(100) NOT NULL COMMENT 'API名称',
|
||
`api_key` varchar(64) NOT NULL COMMENT 'API密钥',
|
||
`api_secret` varchar(64) DEFAULT NULL COMMENT 'API密文',
|
||
`client_id` varchar(100) DEFAULT NULL COMMENT '客户端ID',
|
||
`allowed_ips` varchar(1000) DEFAULT NULL COMMENT '允许的IP地址(多个用逗号分隔)',
|
||
`rate_limit` int DEFAULT 100 COMMENT '限流(每分钟请求数)',
|
||
`status` char(1) DEFAULT '0' COMMENT '状态(0启用 1禁用)',
|
||
`expire_time` datetime DEFAULT NULL COMMENT '过期时间',
|
||
`last_use_time` datetime DEFAULT NULL COMMENT '最后使用时间',
|
||
`create_by` varchar(64) DEFAULT '' COMMENT '创建者',
|
||
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
|
||
`update_by` varchar(64) DEFAULT '' COMMENT '更新者',
|
||
`update_time` datetime DEFAULT NULL COMMENT '更新时间',
|
||
`remark` varchar(500) DEFAULT NULL COMMENT '备注',
|
||
PRIMARY KEY (`config_id`),
|
||
UNIQUE KEY `uk_api_key` (`api_key`),
|
||
KEY `idx_status` (`status`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='开放式API配置表';
|
||
|
||
-- ----------------------------
|
||
-- 16、API调用日志表
|
||
-- ----------------------------
|
||
DROP TABLE IF EXISTS `sys_api_log`;
|
||
CREATE TABLE `sys_api_log` (
|
||
`log_id` bigint NOT NULL AUTO_INCREMENT COMMENT '日志ID',
|
||
`api_key` varchar(64) NOT NULL COMMENT 'API密钥',
|
||
`api_path` varchar(200) NOT NULL COMMENT 'API路径',
|
||
`request_method` varchar(20) DEFAULT NULL COMMENT '请求方法',
|
||
`request_params` text COMMENT '请求参数',
|
||
`response_code` varchar(10) DEFAULT NULL COMMENT '响应码',
|
||
`response_time` int DEFAULT NULL COMMENT '响应时间(毫秒)',
|
||
`ip_address` varchar(128) DEFAULT '' COMMENT 'IP地址',
|
||
`user_agent` varchar(500) DEFAULT NULL COMMENT '用户代理',
|
||
`create_time` datetime DEFAULT NULL COMMENT '调用时间',
|
||
PRIMARY KEY (`log_id`),
|
||
KEY `idx_api_key` (`api_key`),
|
||
KEY `idx_create_time` (`create_time`)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='API调用日志表';
|
||
|
||
-- ----------------------------
|
||
-- 初始化扩展数据字典
|
||
-- ----------------------------
|
||
|
||
-- 档案类型字典
|
||
INSERT INTO `sys_dict_type` (`dict_name`, `dict_type`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES ('档案类型', 'psy_profile_type', '0', 'admin', NOW(), '用户档案类型列表');
|
||
|
||
INSERT INTO `sys_dict_data` (`dict_sort`, `dict_label`, `dict_value`, `dict_type`, `css_class`, `list_class`, `is_default`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES (1, '标准档案', 'standard', 'psy_profile_type', '', 'primary', 'Y', '0', 'admin', NOW(), '标准档案'),
|
||
(2, '儿童档案', 'child', 'psy_profile_type', '', 'success', 'N', '0', 'admin', NOW(), '儿童档案'),
|
||
(3, '成人档案', 'adult', 'psy_profile_type', '', 'info', 'N', '0', 'admin', NOW(), '成人档案'),
|
||
(4, '老年档案', 'senior', 'psy_profile_type', '', 'warning', 'N', '0', 'admin', NOW(), '老年档案');
|
||
|
||
-- 问卷类型字典
|
||
INSERT INTO `sys_dict_type` (`dict_name`, `dict_type`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES ('问卷类型', 'psy_questionnaire_type', '0', 'admin', NOW(), '自定义问卷类型');
|
||
|
||
INSERT INTO `sys_dict_data` (`dict_sort`, `dict_label`, `dict_value`, `dict_type`, `css_class`, `list_class`, `is_default`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES (1, '自定义', 'custom', 'psy_questionnaire_type', '', 'primary', 'Y', '0', 'admin', NOW(), '自定义问卷'),
|
||
(2, '考试', 'exam', 'psy_questionnaire_type', '', 'warning', 'N', '0', 'admin', NOW(), '考试问卷'),
|
||
(3, '练习', 'practice', 'psy_questionnaire_type', '', 'success', 'N', '0', 'admin', NOW(), '练习问卷');
|
||
|
||
-- 组卷方式字典
|
||
INSERT INTO `sys_dict_type` (`dict_name`, `dict_type`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES ('组卷方式', 'psy_paper_type', '0', 'admin', NOW(), '问卷组卷方式');
|
||
|
||
INSERT INTO `sys_dict_data` (`dict_sort`, `dict_label`, `dict_value`, `dict_type`, `css_class`, `list_class`, `is_default`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES (1, '手动', 'manual', 'psy_paper_type', '', 'primary', 'Y', '0', 'admin', NOW(), '手动组卷'),
|
||
(2, '随机', 'random', 'psy_paper_type', '', 'success', 'N', '0', 'admin', NOW(), '随机组卷'),
|
||
(3, '混合', 'mixed', 'psy_paper_type', '', 'info', 'N', '0', 'admin', NOW(), '手动+随机');
|
||
|
||
-- 扩展题目类型字典
|
||
INSERT INTO `sys_dict_data` (`dict_sort`, `dict_label`, `dict_value`, `dict_type`, `css_class`, `list_class`, `is_default`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES (4, '判断题', 'boolean', 'psy_item_type', '', 'info', 'N', '0', 'admin', NOW(), '判断题'),
|
||
(5, '填空题', 'input', 'psy_item_type', '', 'warning', 'N', '0', 'admin', NOW(), '填空题'),
|
||
(6, '排序题', 'sort', 'psy_item_type', '', 'info', 'N', '0', 'admin', NOW(), '排序题'),
|
||
(7, '计算题', 'calculate', 'psy_item_type', '', 'warning', 'N', '0', 'admin', NOW(), '计算题'),
|
||
(8, '简答题', 'text', 'psy_item_type', '', 'info', 'N', '0', 'admin', NOW(), '简答题'),
|
||
(9, '问答题', 'textarea', 'psy_item_type', '', 'warning', 'N', '0', 'admin', NOW(), '问答题'),
|
||
(10, '作文题', 'essay', 'psy_item_type', '', 'success', 'N', '0', 'admin', NOW(), '作文题');
|
||
|
||
-- 预警级别字典
|
||
INSERT INTO `sys_dict_type` (`dict_name`, `dict_type`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES ('预警级别', 'psy_warning_level', '0', 'admin', NOW(), '危机预警级别');
|
||
|
||
INSERT INTO `sys_dict_data` (`dict_sort`, `dict_label`, `dict_value`, `dict_type`, `css_class`, `list_class`, `is_default`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES (1, '低', 'low', 'psy_warning_level', '', 'info', 'N', '0', 'admin', NOW(), '低风险'),
|
||
(2, '中', 'medium', 'psy_warning_level', '', 'warning', 'Y', '0', 'admin', NOW(), '中风险'),
|
||
(3, '高', 'high', 'psy_warning_level', '', 'danger', 'N', '0', 'admin', NOW(), '高风险'),
|
||
(4, '严重', 'critical', 'psy_warning_level', '', 'danger', 'N', '0', 'admin', NOW(), '严重风险');
|
||
|
||
-- 预警状态字典
|
||
INSERT INTO `sys_dict_type` (`dict_name`, `dict_type`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES ('预警状态', 'psy_warning_status', '0', 'admin', NOW(), '危机预警状态');
|
||
|
||
INSERT INTO `sys_dict_data` (`dict_sort`, `dict_label`, `dict_value`, `dict_type`, `css_class`, `list_class`, `is_default`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES (1, '待处理', '0', 'psy_warning_status', '', 'warning', 'Y', '0', 'admin', NOW(), '待处理'),
|
||
(2, '处理中', '1', 'psy_warning_status', '', 'info', 'N', '0', 'admin', NOW(), '处理中'),
|
||
(3, '已解除', '2', 'psy_warning_status', '', 'success', 'N', '0', 'admin', NOW(), '已解除'),
|
||
(4, '已归档', '3', 'psy_warning_status', '', 'default', 'N', '0', 'admin', NOW(), '已归档');
|
||
|
||
-- 二维码类型字典
|
||
INSERT INTO `sys_dict_type` (`dict_name`, `dict_type`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES ('二维码类型', 'psy_qrcode_type', '0', 'admin', NOW(), '二维码类型列表');
|
||
|
||
INSERT INTO `sys_dict_data` (`dict_sort`, `dict_label`, `dict_value`, `dict_type`, `css_class`, `list_class`, `is_default`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES (1, '测评', 'test', 'psy_qrcode_type', '', 'primary', 'Y', '0', 'admin', NOW(), '扫码测评'),
|
||
(2, '查看报告', 'view_report', 'psy_qrcode_type', '', 'success', 'N', '0', 'admin', NOW(), '扫码查看报告'),
|
||
(3, '注册', 'register', 'psy_qrcode_type', '', 'info', 'N', '0', 'admin', NOW(), '扫码注册'),
|
||
(4, '登录', 'login', 'psy_qrcode_type', '', 'warning', 'N', '0', 'admin', NOW(), '扫码登录');
|
||
|
||
-- 备份类型字典
|
||
INSERT INTO `sys_dict_type` (`dict_name`, `dict_type`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES ('备份类型', 'sys_backup_type', '0', 'admin', NOW(), '数据备份类型');
|
||
|
||
INSERT INTO `sys_dict_data` (`dict_sort`, `dict_label`, `dict_value`, `dict_type`, `css_class`, `list_class`, `is_default`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES (1, '全量备份', 'full', 'sys_backup_type', '', 'primary', 'Y', '0', 'admin', NOW(), '全量备份'),
|
||
(2, '增量备份', 'incremental', 'sys_backup_type', '', 'success', 'N', '0', 'admin', NOW(), '增量备份');
|
||
|
||
-- 网站内容类型字典
|
||
INSERT INTO `sys_dict_type` (`dict_name`, `dict_type`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES ('网站内容类型', 'psy_content_type', '0', 'admin', NOW(), '心理网站内容类型');
|
||
|
||
INSERT INTO `sys_dict_data` (`dict_sort`, `dict_label`, `dict_value`, `dict_type`, `css_class`, `list_class`, `is_default`, `status`, `create_by`, `create_time`, `remark`)
|
||
VALUES (1, '文章', 'article', 'psy_content_type', '', 'primary', 'Y', '0', 'admin', NOW(), '文章内容'),
|
||
(2, '公告', 'notice', 'psy_content_type', '', 'warning', 'N', '0', 'admin', NOW(), '公告内容'),
|
||
(3, '横幅', 'banner', 'psy_content_type', '', 'info', 'N', '0', 'admin', NOW(), '横幅图片'),
|
||
(4, '链接', 'link', 'psy_content_type', '', 'success', 'N', '0', 'admin', NOW(), '外链内容');
|
||
|
||
SET FOREIGN_KEY_CHECKS = 1;
|
||
|