数据库设计文档.sql 57 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151
  1. -- =====================================================
  2. -- 科研创新与学科竞赛综合管理系统数据库设计
  3. -- 版本: v1.0
  4. -- 创建日期: 2024年
  5. -- 数据库: MySQL 8.0
  6. -- 字符集: utf8mb4
  7. -- 排序规则: utf8mb4_unicode_ci
  8. -- =====================================================
  9. -- 创建数据库
  10. CREATE DATABASE IF NOT EXISTS inno_res_comp_ms
  11. CHARACTER SET utf8mb4
  12. COLLATE utf8mb4_unicode_ci;
  13. USE inno_res_comp_ms;
  14. -- =====================================================
  15. -- 1. 用户管理模块表结构
  16. -- =====================================================
  17. -- 用户基础信息表
  18. CREATE TABLE users (
  19. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '用户ID',
  20. username VARCHAR(50) NOT NULL UNIQUE COMMENT '用户名',
  21. password VARCHAR(255) NOT NULL COMMENT '密码(加密)',
  22. email VARCHAR(100) UNIQUE COMMENT '邮箱',
  23. phone VARCHAR(20) COMMENT '手机号',
  24. real_name VARCHAR(50) NOT NULL COMMENT '真实姓名',
  25. avatar_url VARCHAR(500) COMMENT '头像URL',
  26. gender TINYINT DEFAULT 0 COMMENT '性别: 0-未知, 1-男, 2-女',
  27. birth_date DATE COMMENT '出生日期',
  28. id_card VARCHAR(18) COMMENT '身份证号',
  29. department_id BIGINT COMMENT '所属部门ID',
  30. status TINYINT DEFAULT 1 COMMENT '状态: 0-禁用, 1-启用',
  31. last_login_time DATETIME COMMENT '最后登录时间',
  32. last_login_ip VARCHAR(45) COMMENT '最后登录IP',
  33. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  34. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  35. INDEX idx_username (username),
  36. INDEX idx_email (email),
  37. INDEX idx_phone (phone),
  38. INDEX idx_department (department_id),
  39. INDEX idx_status (status),
  40. INDEX idx_created_at (created_at)
  41. ) COMMENT '用户基础信息表';
  42. -- 角色表
  43. CREATE TABLE roles (
  44. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '角色ID',
  45. role_name VARCHAR(50) NOT NULL COMMENT '角色名称',
  46. role_code VARCHAR(50) NOT NULL UNIQUE COMMENT '角色编码',
  47. description TEXT COMMENT '角色描述',
  48. permissions JSON COMMENT '权限列表(JSON格式)',
  49. is_system TINYINT DEFAULT 0 COMMENT '是否系统角色: 0-否, 1-是',
  50. status TINYINT DEFAULT 1 COMMENT '状态: 0-禁用, 1-启用',
  51. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  52. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  53. INDEX idx_role_code (role_code),
  54. INDEX idx_status (status)
  55. ) COMMENT '角色表';
  56. -- 用户角色关联表
  57. CREATE TABLE user_roles (
  58. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '关联ID',
  59. user_id BIGINT NOT NULL COMMENT '用户ID',
  60. role_id BIGINT NOT NULL COMMENT '角色ID',
  61. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  62. UNIQUE KEY uk_user_role (user_id, role_id),
  63. INDEX idx_user_id (user_id),
  64. INDEX idx_role_id (role_id),
  65. FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE,
  66. FOREIGN KEY (role_id) REFERENCES roles(id) ON DELETE CASCADE
  67. ) COMMENT '用户角色关联表';
  68. -- 部门表
  69. CREATE TABLE departments (
  70. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '部门ID',
  71. name VARCHAR(100) NOT NULL COMMENT '部门名称',
  72. code VARCHAR(50) UNIQUE COMMENT '部门编码',
  73. parent_id BIGINT DEFAULT 0 COMMENT '父部门ID',
  74. level TINYINT DEFAULT 1 COMMENT '部门层级',
  75. sort_order INT DEFAULT 0 COMMENT '排序',
  76. manager_id BIGINT COMMENT '部门负责人ID',
  77. description TEXT COMMENT '部门描述',
  78. status TINYINT DEFAULT 1 COMMENT '状态: 0-禁用, 1-启用',
  79. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  80. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  81. INDEX idx_parent_id (parent_id),
  82. INDEX idx_code (code),
  83. INDEX idx_manager_id (manager_id),
  84. INDEX idx_status (status)
  85. ) COMMENT '部门表';
  86. -- =====================================================
  87. -- 2. 产教融合模块表结构
  88. -- =====================================================
  89. -- 企业信息表
  90. CREATE TABLE enterprises (
  91. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '企业ID',
  92. name VARCHAR(200) NOT NULL COMMENT '企业名称',
  93. short_name VARCHAR(100) COMMENT '企业简称',
  94. unified_social_credit_code VARCHAR(18) UNIQUE COMMENT '统一社会信用代码',
  95. enterprise_type TINYINT NOT NULL COMMENT '企业类型: 1-国企, 2-民企, 3-外企, 4-合资',
  96. industry VARCHAR(100) COMMENT '所属行业',
  97. scale TINYINT COMMENT '企业规模: 1-大型, 2-中型, 3-小型, 4-微型',
  98. contact_person VARCHAR(50) COMMENT '联系人',
  99. contact_phone VARCHAR(20) COMMENT '联系电话',
  100. contact_email VARCHAR(100) COMMENT '联系邮箱',
  101. address VARCHAR(500) COMMENT '企业地址',
  102. website VARCHAR(200) COMMENT '企业官网',
  103. business_scope TEXT COMMENT '经营范围',
  104. tags JSON COMMENT '企业标签(技术领域、设备类型等)',
  105. cooperation_history JSON COMMENT '合作历史记录',
  106. credit_rating TINYINT DEFAULT 5 COMMENT '信用评级(1-10)',
  107. status TINYINT DEFAULT 1 COMMENT '状态: 0-禁用, 1-启用',
  108. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  109. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  110. INDEX idx_name (name),
  111. INDEX idx_industry (industry),
  112. INDEX idx_enterprise_type (enterprise_type),
  113. INDEX idx_scale (scale),
  114. INDEX idx_status (status),
  115. INDEX idx_credit_rating (credit_rating)
  116. ) COMMENT '企业信息表';
  117. -- 校企合作项目表
  118. CREATE TABLE cooperation_projects (
  119. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '项目ID',
  120. project_name VARCHAR(200) NOT NULL COMMENT '项目名称',
  121. project_code VARCHAR(50) UNIQUE COMMENT '项目编号',
  122. enterprise_id BIGINT NOT NULL COMMENT '合作企业ID',
  123. department_id BIGINT NOT NULL COMMENT '学校部门ID',
  124. project_type TINYINT NOT NULL COMMENT '项目类型: 1-技术开发, 2-人才培养, 3-实习实训, 4-成果转化',
  125. cooperation_mode TINYINT NOT NULL COMMENT '合作模式: 1-委托开发, 2-合作开发, 3-技术服务, 4-人才交流',
  126. project_leader_id BIGINT COMMENT '项目负责人ID',
  127. enterprise_contact_id BIGINT COMMENT '企业联系人ID',
  128. start_date DATE NOT NULL COMMENT '开始日期',
  129. end_date DATE NOT NULL COMMENT '结束日期',
  130. budget DECIMAL(15,2) DEFAULT 0 COMMENT '项目预算',
  131. actual_amount DECIMAL(15,2) DEFAULT 0 COMMENT '实际金额',
  132. project_description TEXT COMMENT '项目描述',
  133. objectives TEXT COMMENT '项目目标',
  134. deliverables TEXT COMMENT '交付成果',
  135. risk_assessment TEXT COMMENT '风险评估',
  136. progress_status TINYINT DEFAULT 1 COMMENT '进度状态: 1-立项, 2-进行中, 3-验收, 4-完成, 5-暂停, 6-终止',
  137. quality_score DECIMAL(3,1) DEFAULT 0 COMMENT '质量评分(0-10)',
  138. satisfaction_score DECIMAL(3,1) DEFAULT 0 COMMENT '满意度评分(0-10)',
  139. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  140. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  141. INDEX idx_project_code (project_code),
  142. INDEX idx_enterprise_id (enterprise_id),
  143. INDEX idx_department_id (department_id),
  144. INDEX idx_project_type (project_type),
  145. INDEX idx_progress_status (progress_status),
  146. INDEX idx_start_date (start_date),
  147. INDEX idx_end_date (end_date),
  148. FOREIGN KEY (enterprise_id) REFERENCES enterprises(id),
  149. FOREIGN KEY (department_id) REFERENCES departments(id),
  150. FOREIGN KEY (project_leader_id) REFERENCES users(id)
  151. ) COMMENT '校企合作项目表';
  152. -- 技术成熟度评估表
  153. CREATE TABLE tech_maturity_assessments (
  154. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '评估ID',
  155. project_id BIGINT NOT NULL COMMENT '项目ID',
  156. assessor_id BIGINT NOT NULL COMMENT '评估人ID',
  157. assessment_round TINYINT DEFAULT 1 COMMENT '评估轮次',
  158. technology_readiness_level TINYINT NOT NULL COMMENT '技术成熟度等级(1-9)',
  159. market_readiness_score DECIMAL(3,1) COMMENT '市场成熟度评分(0-10)',
  160. commercial_potential_score DECIMAL(3,1) COMMENT '商业化潜力评分(0-10)',
  161. risk_level TINYINT COMMENT '风险等级: 1-低, 2-中, 3-高',
  162. assessment_content TEXT COMMENT '评估内容',
  163. improvement_suggestions TEXT COMMENT '改进建议',
  164. next_milestone TEXT COMMENT '下一里程碑',
  165. assessment_date DATE NOT NULL COMMENT '评估日期',
  166. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  167. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  168. INDEX idx_project_id (project_id),
  169. INDEX idx_assessor_id (assessor_id),
  170. INDEX idx_assessment_date (assessment_date),
  171. INDEX idx_trl (technology_readiness_level),
  172. FOREIGN KEY (project_id) REFERENCES cooperation_projects(id),
  173. FOREIGN KEY (assessor_id) REFERENCES users(id)
  174. ) COMMENT '技术成熟度评估表';
  175. -- 路演匹配表
  176. CREATE TABLE roadshow_matches (
  177. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '匹配ID',
  178. project_id BIGINT NOT NULL COMMENT '项目ID',
  179. investor_type TINYINT NOT NULL COMMENT '投资机构类型: 1-天使投资, 2-VC, 3-PE, 4-产业基金',
  180. investor_name VARCHAR(200) COMMENT '投资机构名称',
  181. contact_person VARCHAR(50) COMMENT '联系人',
  182. contact_info VARCHAR(200) COMMENT '联系方式',
  183. match_score DECIMAL(3,1) COMMENT '匹配度评分(0-10)',
  184. match_reason TEXT COMMENT '匹配原因',
  185. roadshow_date DATETIME COMMENT '路演时间',
  186. roadshow_result TINYINT COMMENT '路演结果: 1-通过, 2-待定, 3-拒绝',
  187. feedback TEXT COMMENT '反馈意见',
  188. follow_up_actions TEXT COMMENT '后续行动',
  189. status TINYINT DEFAULT 1 COMMENT '状态: 1-待路演, 2-已路演, 3-已签约, 4-已拒绝',
  190. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  191. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  192. INDEX idx_project_id (project_id),
  193. INDEX idx_investor_type (investor_type),
  194. INDEX idx_roadshow_date (roadshow_date),
  195. INDEX idx_status (status),
  196. FOREIGN KEY (project_id) REFERENCES cooperation_projects(id)
  197. ) COMMENT '路演匹配表';
  198. -- =====================================================
  199. -- 3. 学科竞赛模块表结构
  200. -- =====================================================
  201. -- 竞赛信息表
  202. CREATE TABLE competitions (
  203. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '竞赛ID',
  204. name VARCHAR(200) NOT NULL COMMENT '竞赛名称',
  205. english_name VARCHAR(200) COMMENT '英文名称',
  206. competition_code VARCHAR(50) UNIQUE COMMENT '竞赛编号',
  207. competition_type TINYINT NOT NULL COMMENT '竞赛类型: 1-学科竞赛, 2-创新创业, 3-技能竞赛, 4-文体竞赛',
  208. level TINYINT NOT NULL COMMENT '竞赛级别: 1-国际级, 2-国家级, 3-省部级, 4-市厅级, 5-校级',
  209. category VARCHAR(100) COMMENT '竞赛类别',
  210. organizer VARCHAR(200) COMMENT '主办单位',
  211. co_organizer VARCHAR(500) COMMENT '协办单位',
  212. competition_year YEAR NOT NULL COMMENT '竞赛年度',
  213. registration_start_date DATE COMMENT '报名开始日期',
  214. registration_end_date DATE COMMENT '报名结束日期',
  215. competition_start_date DATE COMMENT '竞赛开始日期',
  216. competition_end_date DATE COMMENT '竞赛结束日期',
  217. venue VARCHAR(200) COMMENT '竞赛地点',
  218. official_website VARCHAR(200) COMMENT '官方网站',
  219. description TEXT COMMENT '竞赛描述',
  220. rules_document_url VARCHAR(500) COMMENT '竞赛规则文档URL',
  221. prize_setting TEXT COMMENT '奖项设置',
  222. registration_fee DECIMAL(10,2) DEFAULT 0 COMMENT '报名费用',
  223. max_team_size INT DEFAULT 1 COMMENT '最大团队人数',
  224. status TINYINT DEFAULT 1 COMMENT '状态: 0-禁用, 1-启用, 2-已结束',
  225. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  226. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  227. INDEX idx_competition_code (competition_code),
  228. INDEX idx_competition_type (competition_type),
  229. INDEX idx_level (level),
  230. INDEX idx_competition_year (competition_year),
  231. INDEX idx_status (status),
  232. INDEX idx_registration_dates (registration_start_date, registration_end_date),
  233. INDEX idx_competition_dates (competition_start_date, competition_end_date)
  234. ) COMMENT '竞赛信息表';
  235. -- 获奖记录表
  236. CREATE TABLE awards (
  237. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '获奖ID',
  238. competition_id BIGINT NOT NULL COMMENT '竞赛ID',
  239. award_name VARCHAR(200) NOT NULL COMMENT '获奖名称',
  240. award_level TINYINT NOT NULL COMMENT '获奖等级: 1-特等奖, 2-一等奖, 3-二等奖, 4-三等奖, 5-优秀奖, 6-其他',
  241. team_name VARCHAR(200) COMMENT '团队名称',
  242. is_team TINYINT DEFAULT 0 COMMENT '是否团队: 0-个人, 1-团队',
  243. team_leader_id BIGINT COMMENT '团队负责人ID',
  244. team_members JSON COMMENT '团队成员ID列表',
  245. instructor_id BIGINT COMMENT '指导教师ID',
  246. co_instructors JSON COMMENT '协助指导教师ID列表',
  247. work_title VARCHAR(200) COMMENT '作品标题',
  248. work_description TEXT COMMENT '作品描述',
  249. certificate_number VARCHAR(100) COMMENT '证书编号',
  250. certificate_url VARCHAR(500) COMMENT '证书文件URL',
  251. supporting_materials JSON COMMENT '佐证材料URL列表',
  252. award_date DATE NOT NULL COMMENT '获奖日期',
  253. points DECIMAL(5,2) DEFAULT 0 COMMENT '获奖积分',
  254. bonus_amount DECIMAL(10,2) DEFAULT 0 COMMENT '奖金金额',
  255. publicity_period_start DATE COMMENT '公示期开始',
  256. publicity_period_end DATE COMMENT '公示期结束',
  257. audit_status TINYINT DEFAULT 0 COMMENT '审核状态: 0-待审核, 1-审核通过, 2-审核驳回, 3-需要补充材料',
  258. audit_comment TEXT COMMENT '审核意见',
  259. auditor_id BIGINT COMMENT '审核人ID',
  260. audit_time DATETIME COMMENT '审核时间',
  261. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  262. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  263. INDEX idx_competition_id (competition_id),
  264. INDEX idx_award_level (award_level),
  265. INDEX idx_team_leader_id (team_leader_id),
  266. INDEX idx_instructor_id (instructor_id),
  267. INDEX idx_award_date (award_date),
  268. INDEX idx_audit_status (audit_status),
  269. INDEX idx_auditor_id (auditor_id),
  270. FOREIGN KEY (competition_id) REFERENCES competitions(id),
  271. FOREIGN KEY (team_leader_id) REFERENCES users(id),
  272. FOREIGN KEY (instructor_id) REFERENCES users(id),
  273. FOREIGN KEY (auditor_id) REFERENCES users(id)
  274. ) COMMENT '获奖记录表';
  275. -- 审核记录表
  276. CREATE TABLE audit_records (
  277. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '审核记录ID',
  278. award_id BIGINT NOT NULL COMMENT '获奖记录ID',
  279. auditor_id BIGINT NOT NULL COMMENT '审核人ID',
  280. audit_action TINYINT NOT NULL COMMENT '审核动作: 1-提交审核, 2-审核通过, 3-审核驳回, 4-要求补充',
  281. audit_status_before TINYINT COMMENT '审核前状态',
  282. audit_status_after TINYINT COMMENT '审核后状态',
  283. audit_comment TEXT COMMENT '审核意见',
  284. required_materials TEXT COMMENT '要求补充的材料',
  285. audit_time DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '审核时间',
  286. ip_address VARCHAR(45) COMMENT '审核IP地址',
  287. INDEX idx_award_id (award_id),
  288. INDEX idx_auditor_id (auditor_id),
  289. INDEX idx_audit_time (audit_time),
  290. FOREIGN KEY (award_id) REFERENCES awards(id),
  291. FOREIGN KEY (auditor_id) REFERENCES users(id)
  292. ) COMMENT '审核记录表';
  293. -- =====================================================
  294. -- 4. 实验室管理模块表结构
  295. -- =====================================================
  296. -- 实验室信息表
  297. CREATE TABLE laboratories (
  298. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '实验室ID',
  299. name VARCHAR(200) NOT NULL COMMENT '实验室名称',
  300. lab_code VARCHAR(50) UNIQUE COMMENT '实验室编号',
  301. lab_type TINYINT NOT NULL COMMENT '实验室类型: 1-教学实验室, 2-科研实验室, 3-开放实验室, 4-虚拟实验室',
  302. department_id BIGINT NOT NULL COMMENT '所属部门ID',
  303. building VARCHAR(100) COMMENT '所在建筑',
  304. floor VARCHAR(20) COMMENT '楼层',
  305. room_number VARCHAR(50) COMMENT '房间号',
  306. area DECIMAL(8,2) COMMENT '面积(平方米)',
  307. capacity INT DEFAULT 0 COMMENT '容纳人数',
  308. manager_id BIGINT COMMENT '实验室负责人ID',
  309. assistant_managers JSON COMMENT '实验室管理员ID列表',
  310. equipment_count INT DEFAULT 0 COMMENT '设备数量',
  311. total_value DECIMAL(15,2) DEFAULT 0 COMMENT '设备总价值',
  312. safety_level TINYINT DEFAULT 1 COMMENT '安全等级: 1-一般, 2-较高, 3-高',
  313. access_control TINYINT DEFAULT 1 COMMENT '门禁控制: 0-无, 1-刷卡, 2-指纹, 3-人脸识别',
  314. opening_hours VARCHAR(200) COMMENT '开放时间',
  315. booking_required TINYINT DEFAULT 1 COMMENT '是否需要预约: 0-否, 1-是',
  316. description TEXT COMMENT '实验室描述',
  317. rules TEXT COMMENT '使用规则',
  318. emergency_contact VARCHAR(200) COMMENT '紧急联系方式',
  319. status TINYINT DEFAULT 1 COMMENT '状态: 0-停用, 1-正常, 2-维护中, 3-装修中',
  320. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  321. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  322. INDEX idx_lab_code (lab_code),
  323. INDEX idx_lab_type (lab_type),
  324. INDEX idx_department_id (department_id),
  325. INDEX idx_manager_id (manager_id),
  326. INDEX idx_status (status),
  327. FOREIGN KEY (department_id) REFERENCES departments(id),
  328. FOREIGN KEY (manager_id) REFERENCES users(id)
  329. ) COMMENT '实验室信息表';
  330. -- 设备信息表
  331. CREATE TABLE equipment (
  332. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '设备ID',
  333. lab_id BIGINT NOT NULL COMMENT '所属实验室ID',
  334. equipment_name VARCHAR(200) NOT NULL COMMENT '设备名称',
  335. equipment_code VARCHAR(50) UNIQUE COMMENT '设备编号',
  336. equipment_type TINYINT NOT NULL COMMENT '设备类型: 1-计算机, 2-测量仪器, 3-实验装置, 4-其他',
  337. brand VARCHAR(100) COMMENT '品牌',
  338. model VARCHAR(100) COMMENT '型号',
  339. specifications TEXT COMMENT '技术规格',
  340. purchase_date DATE COMMENT '购买日期',
  341. purchase_price DECIMAL(12,2) COMMENT '购买价格',
  342. supplier VARCHAR(200) COMMENT '供应商',
  343. warranty_period INT COMMENT '保修期(月)',
  344. warranty_end_date DATE COMMENT '保修到期日期',
  345. depreciation_years INT DEFAULT 5 COMMENT '折旧年限',
  346. current_value DECIMAL(12,2) COMMENT '当前价值',
  347. location VARCHAR(200) COMMENT '存放位置',
  348. responsible_person_id BIGINT COMMENT '责任人ID',
  349. usage_instructions TEXT COMMENT '使用说明',
  350. maintenance_cycle INT COMMENT '维护周期(天)',
  351. last_maintenance_date DATE COMMENT '上次维护日期',
  352. next_maintenance_date DATE COMMENT '下次维护日期',
  353. maintenance_records JSON COMMENT '维护记录',
  354. remote_controllable TINYINT DEFAULT 0 COMMENT '是否支持远程控制: 0-否, 1-是',
  355. remote_control_url VARCHAR(500) COMMENT '远程控制地址',
  356. network_status TINYINT DEFAULT 0 COMMENT '网络状态: 0-离线, 1-在线',
  357. power_status TINYINT DEFAULT 0 COMMENT '电源状态: 0-关闭, 1-开启',
  358. usage_status TINYINT DEFAULT 0 COMMENT '使用状态: 0-空闲, 1-使用中, 2-故障, 3-维护中',
  359. booking_required TINYINT DEFAULT 1 COMMENT '是否需要预约: 0-否, 1-是',
  360. max_booking_duration INT DEFAULT 240 COMMENT '最大预约时长(分钟)',
  361. status TINYINT DEFAULT 1 COMMENT '设备状态: 0-报废, 1-正常, 2-故障, 3-维修中',
  362. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  363. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  364. INDEX idx_equipment_code (equipment_code),
  365. INDEX idx_lab_id (lab_id),
  366. INDEX idx_equipment_type (equipment_type),
  367. INDEX idx_responsible_person_id (responsible_person_id),
  368. INDEX idx_usage_status (usage_status),
  369. INDEX idx_status (status),
  370. INDEX idx_network_status (network_status),
  371. FOREIGN KEY (lab_id) REFERENCES laboratories(id),
  372. FOREIGN KEY (responsible_person_id) REFERENCES users(id)
  373. ) COMMENT '设备信息表';
  374. -- 设备借用记录表
  375. CREATE TABLE equipment_borrowings (
  376. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '借用记录ID',
  377. equipment_id BIGINT NOT NULL COMMENT '设备ID',
  378. borrower_id BIGINT NOT NULL COMMENT '借用人ID',
  379. borrower_type TINYINT NOT NULL COMMENT '借用人类型: 1-学生, 2-教师, 3-外部人员',
  380. purpose TEXT NOT NULL COMMENT '借用目的',
  381. project_id BIGINT COMMENT '关联项目ID',
  382. course_id BIGINT COMMENT '关联课程ID',
  383. planned_start_time DATETIME NOT NULL COMMENT '计划开始时间',
  384. planned_end_time DATETIME NOT NULL COMMENT '计划结束时间',
  385. actual_start_time DATETIME COMMENT '实际开始时间',
  386. actual_end_time DATETIME COMMENT '实际结束时间',
  387. approver_id BIGINT COMMENT '审批人ID',
  388. approval_time DATETIME COMMENT '审批时间',
  389. approval_comment TEXT COMMENT '审批意见',
  390. usage_notes TEXT COMMENT '使用说明',
  391. return_condition TEXT COMMENT '归还状态说明',
  392. damage_description TEXT COMMENT '损坏描述',
  393. compensation_amount DECIMAL(10,2) DEFAULT 0 COMMENT '赔偿金额',
  394. borrowing_status TINYINT DEFAULT 1 COMMENT '借用状态: 1-申请中, 2-已批准, 3-使用中, 4-已归还, 5-逾期, 6-已拒绝',
  395. reminder_sent TINYINT DEFAULT 0 COMMENT '是否已发送提醒: 0-否, 1-是',
  396. rating TINYINT COMMENT '使用评价(1-5星)',
  397. feedback TEXT COMMENT '使用反馈',
  398. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  399. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  400. INDEX idx_equipment_id (equipment_id),
  401. INDEX idx_borrower_id (borrower_id),
  402. INDEX idx_approver_id (approver_id),
  403. INDEX idx_borrowing_status (borrowing_status),
  404. INDEX idx_planned_times (planned_start_time, planned_end_time),
  405. INDEX idx_actual_times (actual_start_time, actual_end_time),
  406. FOREIGN KEY (equipment_id) REFERENCES equipment(id),
  407. FOREIGN KEY (borrower_id) REFERENCES users(id),
  408. FOREIGN KEY (approver_id) REFERENCES users(id)
  409. ) COMMENT '设备借用记录表';
  410. -- 远程控制日志表
  411. CREATE TABLE remote_control_logs (
  412. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '日志ID',
  413. equipment_id BIGINT NOT NULL COMMENT '设备ID',
  414. operator_id BIGINT NOT NULL COMMENT '操作人ID',
  415. operation_type TINYINT NOT NULL COMMENT '操作类型: 1-开机, 2-关机, 3-重启, 4-状态查询, 5-其他',
  416. operation_command VARCHAR(500) COMMENT '操作命令',
  417. operation_result TINYINT COMMENT '操作结果: 0-失败, 1-成功',
  418. result_message TEXT COMMENT '结果消息',
  419. ip_address VARCHAR(45) COMMENT '操作IP地址',
  420. user_agent VARCHAR(500) COMMENT '用户代理',
  421. operation_time DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '操作时间',
  422. INDEX idx_equipment_id (equipment_id),
  423. INDEX idx_operator_id (operator_id),
  424. INDEX idx_operation_type (operation_type),
  425. INDEX idx_operation_time (operation_time),
  426. FOREIGN KEY (equipment_id) REFERENCES equipment(id),
  427. FOREIGN KEY (operator_id) REFERENCES users(id)
  428. ) COMMENT '远程控制日志表';
  429. -- =====================================================
  430. -- 5. 工作室建设与管理模块表结构
  431. -- =====================================================
  432. -- 学生技能标签表
  433. CREATE TABLE student_skills (
  434. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '技能ID',
  435. student_id BIGINT NOT NULL COMMENT '学生ID',
  436. skill_category TINYINT NOT NULL COMMENT '技能类别: 1-编程语言, 2-开发框架, 3-工具软件, 4-专业技能, 5-软技能',
  437. skill_name VARCHAR(100) NOT NULL COMMENT '技能名称',
  438. skill_level TINYINT NOT NULL COMMENT '技能水平: 1-初级, 2-中级, 3-高级, 4-专家',
  439. proficiency_score DECIMAL(3,1) COMMENT '熟练度评分(0-10)',
  440. certification_name VARCHAR(200) COMMENT '认证名称',
  441. certification_url VARCHAR(500) COMMENT '认证证书URL',
  442. certification_date DATE COMMENT '认证日期',
  443. certification_expiry DATE COMMENT '认证到期日期',
  444. self_assessment TEXT COMMENT '自我评价',
  445. teacher_assessment TEXT COMMENT '教师评价',
  446. project_experience TEXT COMMENT '项目经验',
  447. learning_resources TEXT COMMENT '学习资源',
  448. improvement_plan TEXT COMMENT '提升计划',
  449. last_used_date DATE COMMENT '最后使用日期',
  450. usage_frequency TINYINT COMMENT '使用频率: 1-很少, 2-偶尔, 3-经常, 4-每天',
  451. is_verified TINYINT DEFAULT 0 COMMENT '是否已验证: 0-否, 1-是',
  452. verifier_id BIGINT COMMENT '验证人ID',
  453. verification_date DATE COMMENT '验证日期',
  454. status TINYINT DEFAULT 1 COMMENT '状态: 0-已删除, 1-有效',
  455. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  456. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  457. INDEX idx_student_id (student_id),
  458. INDEX idx_skill_category (skill_category),
  459. INDEX idx_skill_name (skill_name),
  460. INDEX idx_skill_level (skill_level),
  461. INDEX idx_is_verified (is_verified),
  462. INDEX idx_status (status),
  463. FOREIGN KEY (student_id) REFERENCES users(id),
  464. FOREIGN KEY (verifier_id) REFERENCES users(id)
  465. ) COMMENT '学生技能标签表';
  466. -- 学生可用时间表
  467. CREATE TABLE student_availability (
  468. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '可用时间ID',
  469. student_id BIGINT NOT NULL COMMENT '学生ID',
  470. semester VARCHAR(20) NOT NULL COMMENT '学期',
  471. week_day TINYINT NOT NULL COMMENT '星期几(1-7)',
  472. start_time TIME NOT NULL COMMENT '开始时间',
  473. end_time TIME NOT NULL COMMENT '结束时间',
  474. availability_type TINYINT NOT NULL COMMENT '时间类型: 1-空闲, 2-课程, 3-项目, 4-其他',
  475. description VARCHAR(200) COMMENT '描述',
  476. is_flexible TINYINT DEFAULT 1 COMMENT '是否灵活: 0-固定, 1-灵活',
  477. priority TINYINT DEFAULT 3 COMMENT '优先级: 1-低, 2-中, 3-高',
  478. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  479. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  480. INDEX idx_student_id (student_id),
  481. INDEX idx_semester (semester),
  482. INDEX idx_week_day (week_day),
  483. INDEX idx_availability_type (availability_type),
  484. FOREIGN KEY (student_id) REFERENCES users(id)
  485. ) COMMENT '学生可用时间表';
  486. -- 项目信息表
  487. CREATE TABLE projects (
  488. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '项目ID',
  489. project_name VARCHAR(200) NOT NULL COMMENT '项目名称',
  490. project_code VARCHAR(50) UNIQUE COMMENT '项目编号',
  491. project_type TINYINT NOT NULL COMMENT '项目类型: 1-科研项目, 2-竞赛项目, 3-实训项目, 4-创业项目',
  492. project_category VARCHAR(100) COMMENT '项目类别',
  493. teacher_id BIGINT NOT NULL COMMENT '指导教师ID',
  494. co_teachers JSON COMMENT '协助教师ID列表',
  495. department_id BIGINT COMMENT '所属部门ID',
  496. project_description TEXT COMMENT '项目描述',
  497. objectives TEXT COMMENT '项目目标',
  498. expected_outcomes TEXT COMMENT '预期成果',
  499. technical_requirements TEXT COMMENT '技术要求',
  500. skill_requirements JSON COMMENT '技能要求',
  501. team_size_min INT DEFAULT 1 COMMENT '最小团队人数',
  502. team_size_max INT DEFAULT 10 COMMENT '最大团队人数',
  503. difficulty_level TINYINT NOT NULL COMMENT '难度等级: 1-初级, 2-中级, 3-高级, 4-专家',
  504. estimated_duration INT COMMENT '预计持续时间(天)',
  505. start_date DATE COMMENT '开始日期',
  506. end_date DATE COMMENT '结束日期',
  507. budget DECIMAL(12,2) DEFAULT 0 COMMENT '项目预算',
  508. funding_source VARCHAR(200) COMMENT '资金来源',
  509. recruitment_status TINYINT DEFAULT 1 COMMENT '招募状态: 0-未开始, 1-招募中, 2-已满员, 3-已结束',
  510. project_status TINYINT DEFAULT 1 COMMENT '项目状态: 1-立项, 2-进行中, 3-暂停, 4-完成, 5-终止',
  511. progress_percentage DECIMAL(5,2) DEFAULT 0 COMMENT '进度百分比',
  512. health_status TINYINT DEFAULT 1 COMMENT '健康状态: 1-健康, 2-风险, 3-问题',
  513. quality_score DECIMAL(3,1) DEFAULT 0 COMMENT '质量评分(0-10)',
  514. innovation_score DECIMAL(3,1) DEFAULT 0 COMMENT '创新性评分(0-10)',
  515. practical_score DECIMAL(3,1) DEFAULT 0 COMMENT '实用性评分(0-10)',
  516. final_score DECIMAL(3,1) DEFAULT 0 COMMENT '最终评分(0-10)',
  517. achievements TEXT COMMENT '项目成果',
  518. lessons_learned TEXT COMMENT '经验教训',
  519. next_steps TEXT COMMENT '后续计划',
  520. visibility TINYINT DEFAULT 1 COMMENT '可见性: 0-私有, 1-公开, 2-部门内',
  521. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  522. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  523. INDEX idx_project_code (project_code),
  524. INDEX idx_project_type (project_type),
  525. INDEX idx_teacher_id (teacher_id),
  526. INDEX idx_department_id (department_id),
  527. INDEX idx_recruitment_status (recruitment_status),
  528. INDEX idx_project_status (project_status),
  529. INDEX idx_difficulty_level (difficulty_level),
  530. INDEX idx_start_date (start_date),
  531. INDEX idx_end_date (end_date),
  532. FOREIGN KEY (teacher_id) REFERENCES users(id),
  533. FOREIGN KEY (department_id) REFERENCES departments(id)
  534. ) COMMENT '项目信息表';
  535. -- 项目成员表
  536. CREATE TABLE project_members (
  537. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '成员ID',
  538. project_id BIGINT NOT NULL COMMENT '项目ID',
  539. student_id BIGINT NOT NULL COMMENT '学生ID',
  540. member_role TINYINT NOT NULL COMMENT '成员角色: 1-组长, 2-核心成员, 3-普通成员, 4-实习成员',
  541. responsibilities TEXT COMMENT '职责描述',
  542. join_date DATE NOT NULL COMMENT '加入日期',
  543. leave_date DATE COMMENT '离开日期',
  544. planned_workload DECIMAL(5,2) DEFAULT 0 COMMENT '计划工作量(小时/周)',
  545. actual_workload DECIMAL(5,2) DEFAULT 0 COMMENT '实际工作量(小时/周)',
  546. contribution_rate DECIMAL(5,2) DEFAULT 0 COMMENT '贡献度百分比',
  547. performance_score DECIMAL(3,1) DEFAULT 0 COMMENT '表现评分(0-10)',
  548. attendance_rate DECIMAL(5,2) DEFAULT 100 COMMENT '出勤率百分比',
  549. task_completion_rate DECIMAL(5,2) DEFAULT 0 COMMENT '任务完成率百分比',
  550. quality_rating TINYINT DEFAULT 3 COMMENT '质量评级: 1-差, 2-一般, 3-良好, 4-优秀, 5-卓越',
  551. collaboration_rating TINYINT DEFAULT 3 COMMENT '协作评级: 1-差, 2-一般, 3-良好, 4-优秀, 5-卓越',
  552. innovation_rating TINYINT DEFAULT 3 COMMENT '创新评级: 1-差, 2-一般, 3-良好, 4-优秀, 5-卓越',
  553. learning_growth TEXT COMMENT '学习成长',
  554. achievements TEXT COMMENT '个人成果',
  555. feedback_from_teacher TEXT COMMENT '教师反馈',
  556. feedback_from_peers TEXT COMMENT '同伴反馈',
  557. self_reflection TEXT COMMENT '自我反思',
  558. member_status TINYINT DEFAULT 1 COMMENT '成员状态: 1-活跃, 2-请假, 3-已退出, 4-被移除',
  559. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  560. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  561. UNIQUE KEY uk_project_student (project_id, student_id),
  562. INDEX idx_project_id (project_id),
  563. INDEX idx_student_id (student_id),
  564. INDEX idx_member_role (member_role),
  565. INDEX idx_member_status (member_status),
  566. INDEX idx_join_date (join_date),
  567. FOREIGN KEY (project_id) REFERENCES projects(id),
  568. FOREIGN KEY (student_id) REFERENCES users(id)
  569. ) COMMENT '项目成员表';
  570. -- 项目任务表
  571. CREATE TABLE project_tasks (
  572. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '任务ID',
  573. project_id BIGINT NOT NULL COMMENT '项目ID',
  574. parent_task_id BIGINT DEFAULT 0 COMMENT '父任务ID',
  575. task_name VARCHAR(200) NOT NULL COMMENT '任务名称',
  576. task_description TEXT COMMENT '任务描述',
  577. task_type TINYINT NOT NULL COMMENT '任务类型: 1-需求分析, 2-设计, 3-开发, 4-测试, 5-文档, 6-其他',
  578. priority TINYINT DEFAULT 3 COMMENT '优先级: 1-低, 2-中, 3-高, 4-紧急',
  579. difficulty TINYINT DEFAULT 2 COMMENT '难度: 1-简单, 2-中等, 3-困难, 4-很困难',
  580. estimated_hours DECIMAL(6,2) DEFAULT 0 COMMENT '预估工时',
  581. actual_hours DECIMAL(6,2) DEFAULT 0 COMMENT '实际工时',
  582. assignee_id BIGINT COMMENT '负责人ID',
  583. reviewer_id BIGINT COMMENT '审核人ID',
  584. planned_start_date DATE COMMENT '计划开始日期',
  585. planned_end_date DATE COMMENT '计划结束日期',
  586. actual_start_date DATE COMMENT '实际开始日期',
  587. actual_end_date DATE COMMENT '实际结束日期',
  588. progress_percentage DECIMAL(5,2) DEFAULT 0 COMMENT '进度百分比',
  589. task_status TINYINT DEFAULT 1 COMMENT '任务状态: 1-待开始, 2-进行中, 3-待审核, 4-已完成, 5-已取消, 6-已延期',
  590. quality_score DECIMAL(3,1) DEFAULT 0 COMMENT '质量评分(0-10)',
  591. rework_count INT DEFAULT 0 COMMENT '返工次数',
  592. rework_reason TEXT COMMENT '返工原因',
  593. deliverables TEXT COMMENT '交付物',
  594. acceptance_criteria TEXT COMMENT '验收标准',
  595. notes TEXT COMMENT '备注',
  596. tags JSON COMMENT '标签',
  597. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  598. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  599. INDEX idx_project_id (project_id),
  600. INDEX idx_parent_task_id (parent_task_id),
  601. INDEX idx_assignee_id (assignee_id),
  602. INDEX idx_reviewer_id (reviewer_id),
  603. INDEX idx_task_status (task_status),
  604. INDEX idx_priority (priority),
  605. INDEX idx_planned_dates (planned_start_date, planned_end_date),
  606. FOREIGN KEY (project_id) REFERENCES projects(id),
  607. FOREIGN KEY (assignee_id) REFERENCES users(id),
  608. FOREIGN KEY (reviewer_id) REFERENCES users(id)
  609. ) COMMENT '项目任务表';
  610. -- 项目申请表
  611. CREATE TABLE project_applications (
  612. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '申请ID',
  613. project_id BIGINT NOT NULL COMMENT '项目ID',
  614. student_id BIGINT NOT NULL COMMENT '申请学生ID',
  615. application_type TINYINT NOT NULL COMMENT '申请类型: 1-加入项目, 2-退出项目, 3-角色变更',
  616. desired_role TINYINT COMMENT '期望角色: 1-组长, 2-核心成员, 3-普通成员',
  617. motivation TEXT NOT NULL COMMENT '申请动机',
  618. relevant_skills JSON COMMENT '相关技能',
  619. previous_experience TEXT COMMENT '相关经验',
  620. available_time_per_week DECIMAL(4,1) COMMENT '每周可投入时间(小时)',
  621. expected_contribution TEXT COMMENT '预期贡献',
  622. portfolio_url VARCHAR(500) COMMENT '作品集URL',
  623. recommendation_letter_url VARCHAR(500) COMMENT '推荐信URL',
  624. application_status TINYINT DEFAULT 1 COMMENT '申请状态: 1-待审核, 2-已通过, 3-已拒绝, 4-已撤回',
  625. reviewer_id BIGINT COMMENT '审核人ID',
  626. review_comment TEXT COMMENT '审核意见',
  627. review_time DATETIME COMMENT '审核时间',
  628. interview_required TINYINT DEFAULT 0 COMMENT '是否需要面试: 0-否, 1-是',
  629. interview_time DATETIME COMMENT '面试时间',
  630. interview_feedback TEXT COMMENT '面试反馈',
  631. rejection_reason TEXT COMMENT '拒绝原因',
  632. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  633. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  634. INDEX idx_project_id (project_id),
  635. INDEX idx_student_id (student_id),
  636. INDEX idx_application_status (application_status),
  637. INDEX idx_reviewer_id (reviewer_id),
  638. INDEX idx_created_at (created_at),
  639. FOREIGN KEY (project_id) REFERENCES projects(id),
  640. FOREIGN KEY (student_id) REFERENCES users(id),
  641. FOREIGN KEY (reviewer_id) REFERENCES users(id)
  642. ) COMMENT '项目申请表';
  643. -- =====================================================
  644. -- 6. 科研与国际化模块表结构
  645. -- =====================================================
  646. -- 短期交流项目表
  647. CREATE TABLE exchange_programs (
  648. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '项目ID',
  649. program_name VARCHAR(200) NOT NULL COMMENT '项目名称',
  650. program_code VARCHAR(50) UNIQUE COMMENT '项目编号',
  651. program_type TINYINT NOT NULL COMMENT '项目类型: 1-学术交流, 2-实习实训, 3-文化交流, 4-研究合作',
  652. partner_institution VARCHAR(200) NOT NULL COMMENT '合作机构',
  653. partner_country VARCHAR(100) NOT NULL COMMENT '合作国家',
  654. partner_city VARCHAR(100) COMMENT '合作城市',
  655. program_duration INT NOT NULL COMMENT '项目时长(天)',
  656. start_date DATE NOT NULL COMMENT '开始日期',
  657. end_date DATE NOT NULL COMMENT '结束日期',
  658. application_deadline DATE NOT NULL COMMENT '申请截止日期',
  659. max_participants INT DEFAULT 0 COMMENT '最大参与人数',
  660. current_participants INT DEFAULT 0 COMMENT '当前参与人数',
  661. target_audience TINYINT NOT NULL COMMENT '目标群体: 1-本科生, 2-研究生, 3-博士生, 4-教师, 5-全部',
  662. language_requirement VARCHAR(100) COMMENT '语言要求',
  663. gpa_requirement DECIMAL(3,2) COMMENT 'GPA要求',
  664. major_requirements JSON COMMENT '专业要求',
  665. program_description TEXT COMMENT '项目描述',
  666. learning_objectives TEXT COMMENT '学习目标',
  667. activities TEXT COMMENT '活动安排',
  668. accommodation_info TEXT COMMENT '住宿信息',
  669. cost_info TEXT COMMENT '费用信息',
  670. scholarship_available TINYINT DEFAULT 0 COMMENT '是否有奖学金: 0-否, 1-是',
  671. scholarship_amount DECIMAL(10,2) DEFAULT 0 COMMENT '奖学金金额',
  672. application_requirements TEXT COMMENT '申请要求',
  673. required_documents JSON COMMENT '所需文档',
  674. contact_person VARCHAR(100) COMMENT '联系人',
  675. contact_email VARCHAR(100) COMMENT '联系邮箱',
  676. contact_phone VARCHAR(20) COMMENT '联系电话',
  677. program_status TINYINT DEFAULT 1 COMMENT '项目状态: 1-招募中, 2-已满员, 3-进行中, 4-已结束, 5-已取消',
  678. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  679. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  680. INDEX idx_program_code (program_code),
  681. INDEX idx_program_type (program_type),
  682. INDEX idx_partner_country (partner_country),
  683. INDEX idx_target_audience (target_audience),
  684. INDEX idx_application_deadline (application_deadline),
  685. INDEX idx_program_status (program_status),
  686. INDEX idx_start_date (start_date)
  687. ) COMMENT '短期交流项目表';
  688. -- 交流项目申请表
  689. CREATE TABLE exchange_applications (
  690. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '申请ID',
  691. program_id BIGINT NOT NULL COMMENT '项目ID',
  692. applicant_id BIGINT NOT NULL COMMENT '申请人ID',
  693. application_form JSON COMMENT '申请表单数据',
  694. motivation_letter_url VARCHAR(500) COMMENT '动机信URL',
  695. recommendation_letters JSON COMMENT '推荐信URL列表',
  696. transcript_url VARCHAR(500) COMMENT '成绩单URL',
  697. language_certificate_url VARCHAR(500) COMMENT '语言证书URL',
  698. passport_url VARCHAR(500) COMMENT '护照URL',
  699. other_documents JSON COMMENT '其他文档URL列表',
  700. current_gpa DECIMAL(3,2) COMMENT '当前GPA',
  701. language_proficiency VARCHAR(100) COMMENT '语言水平',
  702. previous_exchange_experience TEXT COMMENT '以往交流经验',
  703. special_requirements TEXT COMMENT '特殊要求',
  704. emergency_contact JSON COMMENT '紧急联系人信息',
  705. application_status TINYINT DEFAULT 1 COMMENT '申请状态: 1-待审核, 2-初审通过, 3-面试通过, 4-最终录取, 5-已拒绝, 6-已撤回',
  706. reviewer_id BIGINT COMMENT '审核人ID',
  707. review_score DECIMAL(3,1) DEFAULT 0 COMMENT '审核评分(0-10)',
  708. review_comment TEXT COMMENT '审核意见',
  709. interview_required TINYINT DEFAULT 0 COMMENT '是否需要面试: 0-否, 1-是',
  710. interview_time DATETIME COMMENT '面试时间',
  711. interview_score DECIMAL(3,1) DEFAULT 0 COMMENT '面试评分(0-10)',
  712. interview_feedback TEXT COMMENT '面试反馈',
  713. final_decision TINYINT COMMENT '最终决定: 1-录取, 2-候补, 3-拒绝',
  714. decision_reason TEXT COMMENT '决定原因',
  715. notification_sent TINYINT DEFAULT 0 COMMENT '是否已发送通知: 0-否, 1-是',
  716. acceptance_deadline DATE COMMENT '接受截止日期',
  717. participant_response TINYINT COMMENT '参与者回复: 1-接受, 2-拒绝',
  718. response_time DATETIME COMMENT '回复时间',
  719. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  720. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  721. INDEX idx_program_id (program_id),
  722. INDEX idx_applicant_id (applicant_id),
  723. INDEX idx_application_status (application_status),
  724. INDEX idx_reviewer_id (reviewer_id),
  725. INDEX idx_created_at (created_at),
  726. FOREIGN KEY (program_id) REFERENCES exchange_programs(id),
  727. FOREIGN KEY (applicant_id) REFERENCES users(id),
  728. FOREIGN KEY (reviewer_id) REFERENCES users(id)
  729. ) COMMENT '交流项目申请表';
  730. -- 科研项目表
  731. CREATE TABLE research_projects (
  732. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '科研项目ID',
  733. project_name VARCHAR(200) NOT NULL COMMENT '项目名称',
  734. project_code VARCHAR(50) UNIQUE COMMENT '项目编号',
  735. project_type TINYINT NOT NULL COMMENT '项目类型: 1-国家级, 2-省部级, 3-市厅级, 4-校级, 5-企业合作',
  736. funding_agency VARCHAR(200) COMMENT '资助机构',
  737. principal_investigator_id BIGINT NOT NULL COMMENT '项目负责人ID',
  738. co_investigators JSON COMMENT '合作研究者ID列表',
  739. department_id BIGINT COMMENT '所属部门ID',
  740. research_field VARCHAR(100) COMMENT '研究领域',
  741. keywords JSON COMMENT '关键词',
  742. project_abstract TEXT COMMENT '项目摘要',
  743. research_objectives TEXT COMMENT '研究目标',
  744. research_methodology TEXT COMMENT '研究方法',
  745. expected_outcomes TEXT COMMENT '预期成果',
  746. innovation_points TEXT COMMENT '创新点',
  747. total_budget DECIMAL(15,2) DEFAULT 0 COMMENT '总预算',
  748. approved_budget DECIMAL(15,2) DEFAULT 0 COMMENT '批准预算',
  749. used_budget DECIMAL(15,2) DEFAULT 0 COMMENT '已使用预算',
  750. start_date DATE NOT NULL COMMENT '开始日期',
  751. end_date DATE NOT NULL COMMENT '结束日期',
  752. current_phase TINYINT DEFAULT 1 COMMENT '当前阶段: 1-申报, 2-立项, 3-执行, 4-结题, 5-验收',
  753. progress_percentage DECIMAL(5,2) DEFAULT 0 COMMENT '进度百分比',
  754. milestone_plan JSON COMMENT '里程碑计划',
  755. risk_assessment TEXT COMMENT '风险评估',
  756. quality_control_plan TEXT COMMENT '质量控制计划',
  757. ethics_approval_required TINYINT DEFAULT 0 COMMENT '是否需要伦理审批: 0-否, 1-是',
  758. ethics_approval_status TINYINT DEFAULT 0 COMMENT '伦理审批状态: 0-未申请, 1-审批中, 2-已通过, 3-被拒绝',
  759. intellectual_property_plan TEXT COMMENT '知识产权计划',
  760. collaboration_agreements JSON COMMENT '合作协议',
  761. project_status TINYINT DEFAULT 1 COMMENT '项目状态: 1-申报中, 2-立项, 3-执行中, 4-暂停, 5-完成, 6-终止',
  762. final_report_url VARCHAR(500) COMMENT '结题报告URL',
  763. achievements JSON COMMENT '项目成果',
  764. publications JSON COMMENT '发表论文',
  765. patents JSON COMMENT '专利申请',
  766. awards JSON COMMENT '获得奖项',
  767. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  768. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  769. INDEX idx_project_code (project_code),
  770. INDEX idx_project_type (project_type),
  771. INDEX idx_principal_investigator_id (principal_investigator_id),
  772. INDEX idx_department_id (department_id),
  773. INDEX idx_research_field (research_field),
  774. INDEX idx_current_phase (current_phase),
  775. INDEX idx_project_status (project_status),
  776. INDEX idx_start_date (start_date),
  777. INDEX idx_end_date (end_date),
  778. FOREIGN KEY (principal_investigator_id) REFERENCES users(id),
  779. FOREIGN KEY (department_id) REFERENCES departments(id)
  780. ) COMMENT '科研项目表';
  781. -- =====================================================
  782. -- 7. 系统管理表结构
  783. -- =====================================================
  784. -- 系统配置表
  785. CREATE TABLE system_configs (
  786. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '配置ID',
  787. config_key VARCHAR(100) NOT NULL UNIQUE COMMENT '配置键',
  788. config_value TEXT COMMENT '配置值',
  789. config_type TINYINT DEFAULT 1 COMMENT '配置类型: 1-字符串, 2-数字, 3-布尔, 4-JSON',
  790. config_group VARCHAR(50) COMMENT '配置分组',
  791. description TEXT COMMENT '配置描述',
  792. is_system TINYINT DEFAULT 0 COMMENT '是否系统配置: 0-否, 1-是',
  793. is_encrypted TINYINT DEFAULT 0 COMMENT '是否加密: 0-否, 1-是',
  794. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  795. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  796. INDEX idx_config_key (config_key),
  797. INDEX idx_config_group (config_group)
  798. ) COMMENT '系统配置表';
  799. -- 文件管理表
  800. CREATE TABLE file_storage (
  801. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '文件ID',
  802. original_name VARCHAR(255) NOT NULL COMMENT '原始文件名',
  803. stored_name VARCHAR(255) NOT NULL COMMENT '存储文件名',
  804. file_path VARCHAR(500) NOT NULL COMMENT '文件路径',
  805. file_size BIGINT NOT NULL COMMENT '文件大小(字节)',
  806. file_type VARCHAR(100) COMMENT '文件类型',
  807. mime_type VARCHAR(100) COMMENT 'MIME类型',
  808. file_hash VARCHAR(64) COMMENT '文件哈希值',
  809. uploader_id BIGINT NOT NULL COMMENT '上传者ID',
  810. business_type VARCHAR(50) COMMENT '业务类型',
  811. business_id BIGINT COMMENT '业务ID',
  812. access_level TINYINT DEFAULT 1 COMMENT '访问级别: 1-公开, 2-登录可见, 3-权限控制',
  813. download_count INT DEFAULT 0 COMMENT '下载次数',
  814. is_deleted TINYINT DEFAULT 0 COMMENT '是否已删除: 0-否, 1-是',
  815. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  816. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  817. INDEX idx_stored_name (stored_name),
  818. INDEX idx_uploader_id (uploader_id),
  819. INDEX idx_business (business_type, business_id),
  820. INDEX idx_file_hash (file_hash),
  821. INDEX idx_created_at (created_at),
  822. FOREIGN KEY (uploader_id) REFERENCES users(id)
  823. ) COMMENT '文件管理表';
  824. -- 操作日志表
  825. CREATE TABLE operation_logs (
  826. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '日志ID',
  827. user_id BIGINT COMMENT '操作用户ID',
  828. username VARCHAR(50) COMMENT '用户名',
  829. operation_type VARCHAR(50) NOT NULL COMMENT '操作类型',
  830. operation_name VARCHAR(100) NOT NULL COMMENT '操作名称',
  831. operation_method VARCHAR(10) COMMENT '请求方法',
  832. operation_url VARCHAR(500) COMMENT '请求URL',
  833. operation_params TEXT COMMENT '请求参数',
  834. operation_result TINYINT DEFAULT 1 COMMENT '操作结果: 0-失败, 1-成功',
  835. error_message TEXT COMMENT '错误信息',
  836. execution_time INT DEFAULT 0 COMMENT '执行时间(毫秒)',
  837. ip_address VARCHAR(45) COMMENT 'IP地址',
  838. user_agent VARCHAR(500) COMMENT '用户代理',
  839. browser VARCHAR(100) COMMENT '浏览器',
  840. operating_system VARCHAR(100) COMMENT '操作系统',
  841. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  842. INDEX idx_user_id (user_id),
  843. INDEX idx_operation_type (operation_type),
  844. INDEX idx_operation_result (operation_result),
  845. INDEX idx_created_at (created_at),
  846. INDEX idx_ip_address (ip_address),
  847. FOREIGN KEY (user_id) REFERENCES users(id)
  848. ) COMMENT '操作日志表';
  849. -- 通知消息表
  850. CREATE TABLE notifications (
  851. id BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '通知ID',
  852. title VARCHAR(200) NOT NULL COMMENT '通知标题',
  853. content TEXT NOT NULL COMMENT '通知内容',
  854. notification_type TINYINT NOT NULL COMMENT '通知类型: 1-系统通知, 2-项目通知, 3-竞赛通知, 4-审核通知',
  855. sender_id BIGINT COMMENT '发送者ID',
  856. receiver_id BIGINT NOT NULL COMMENT '接收者ID',
  857. business_type VARCHAR(50) COMMENT '业务类型',
  858. business_id BIGINT COMMENT '业务ID',
  859. priority TINYINT DEFAULT 2 COMMENT '优先级: 1-低, 2-中, 3-高, 4-紧急',
  860. is_read TINYINT DEFAULT 0 COMMENT '是否已读: 0-未读, 1-已读',
  861. read_time DATETIME COMMENT '阅读时间',
  862. is_deleted TINYINT DEFAULT 0 COMMENT '是否已删除: 0-否, 1-是',
  863. created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  864. updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  865. INDEX idx_receiver_id (receiver_id),
  866. INDEX idx_sender_id (sender_id),
  867. INDEX idx_notification_type (notification_type),
  868. INDEX idx_is_read (is_read),
  869. INDEX idx_created_at (created_at),
  870. FOREIGN KEY (sender_id) REFERENCES users(id),
  871. FOREIGN KEY (receiver_id) REFERENCES users(id)
  872. ) COMMENT '通知消息表';
  873. -- =====================================================
  874. -- 8. 初始化数据
  875. -- =====================================================
  876. -- 插入默认角色
  877. INSERT INTO roles (role_name, role_code, description, is_system, permissions) VALUES
  878. ('系统管理员', 'ADMIN', '系统管理员,拥有所有权限', 1, '["*"]'),
  879. ('教师', 'TEACHER', '教师角色,可以指导项目和竞赛', 1, '["project:manage", "competition:manage", "student:view"]'),
  880. ('学生', 'STUDENT', '学生角色,可以参与项目和竞赛', 1, '["project:join", "competition:join", "profile:manage"]'),
  881. ('企业用户', 'ENTERPRISE', '企业用户,可以参与产教融合', 1, '["cooperation:manage", "project:view"]'),
  882. ('实验室管理员', 'LAB_ADMIN', '实验室管理员,管理实验室和设备', 1, '["lab:manage", "equipment:manage"]');
  883. -- 插入默认部门
  884. INSERT INTO departments (name, code, parent_id, level, description) VALUES
  885. ('计算机学院', 'CS', 0, 1, '计算机科学与技术学院'),
  886. ('电子信息学院', 'EE', 0, 1, '电子信息工程学院'),
  887. ('机械工程学院', 'ME', 0, 1, '机械工程学院'),
  888. ('管理学院', 'MBA', 0, 1, '工商管理学院'),
  889. ('科研处', 'RESEARCH', 0, 1, '科学研究处'),
  890. ('教务处', 'ACADEMIC', 0, 1, '教务处'),
  891. ('学生处', 'STUDENT_AFFAIRS', 0, 1, '学生工作处');
  892. -- 插入系统配置
  893. INSERT INTO system_configs (config_key, config_value, config_type, config_group, description) VALUES
  894. ('system.name', '科研创新与学科竞赛综合管理系统', 1, 'system', '系统名称'),
  895. ('system.version', '1.0.0', 1, 'system', '系统版本'),
  896. ('file.upload.max_size', '104857600', 2, 'file', '文件上传最大大小(字节)'),
  897. ('file.upload.allowed_types', '["pdf","doc","docx","xls","xlsx","ppt","pptx","jpg","jpeg","png","gif"]', 4, 'file', '允许上传的文件类型'),
  898. ('notification.email.enabled', 'true', 3, 'notification', '是否启用邮件通知'),
  899. ('notification.sms.enabled', 'false', 3, 'notification', '是否启用短信通知'),
  900. ('security.password.min_length', '8', 2, 'security', '密码最小长度'),
  901. ('security.session.timeout', '7200', 2, 'security', '会话超时时间(秒)'),
  902. ('competition.auto_audit', 'false', 3, 'competition', '竞赛获奖是否自动审核'),
  903. ('project.max_members', '10', 2, 'project', '项目最大成员数');
  904. -- =====================================================
  905. -- 9. 视图定义
  906. -- =====================================================
  907. -- 用户详细信息视图
  908. CREATE VIEW v_user_details AS
  909. SELECT
  910. u.id,
  911. u.username,
  912. u.email,
  913. u.phone,
  914. u.real_name,
  915. u.avatar_url,
  916. u.gender,
  917. u.birth_date,
  918. u.status,
  919. u.last_login_time,
  920. d.name AS department_name,
  921. d.code AS department_code,
  922. GROUP_CONCAT(r.role_name) AS roles,
  923. GROUP_CONCAT(r.role_code) AS role_codes,
  924. u.created_at,
  925. u.updated_at
  926. FROM users u
  927. LEFT JOIN departments d ON u.department_id = d.id
  928. LEFT JOIN user_roles ur ON u.id = ur.user_id
  929. LEFT JOIN roles r ON ur.role_id = r.id
  930. WHERE u.status = 1
  931. GROUP BY u.id;
  932. -- 项目统计视图
  933. CREATE VIEW v_project_statistics AS
  934. SELECT
  935. p.id,
  936. p.project_name,
  937. p.project_code,
  938. p.project_type,
  939. p.project_status,
  940. p.teacher_id,
  941. t.real_name AS teacher_name,
  942. d.name AS department_name,
  943. COUNT(pm.id) AS member_count,
  944. COUNT(pt.id) AS task_count,
  945. AVG(pt.progress_percentage) AS avg_task_progress,
  946. p.progress_percentage,
  947. p.health_status,
  948. p.start_date,
  949. p.end_date,
  950. DATEDIFF(p.end_date, CURDATE()) AS days_remaining
  951. FROM projects p
  952. LEFT JOIN users t ON p.teacher_id = t.id
  953. LEFT JOIN departments d ON p.department_id = d.id
  954. LEFT JOIN project_members pm ON p.id = pm.project_id AND pm.member_status = 1
  955. LEFT JOIN project_tasks pt ON p.id = pt.project_id
  956. GROUP BY p.id;
  957. -- 竞赛获奖统计视图
  958. CREATE VIEW v_competition_award_statistics AS
  959. SELECT
  960. c.id AS competition_id,
  961. c.name AS competition_name,
  962. c.competition_type,
  963. c.level,
  964. c.competition_year,
  965. COUNT(a.id) AS total_awards,
  966. COUNT(CASE WHEN a.award_level = 1 THEN 1 END) AS special_awards,
  967. COUNT(CASE WHEN a.award_level = 2 THEN 1 END) AS first_awards,
  968. COUNT(CASE WHEN a.award_level = 3 THEN 1 END) AS second_awards,
  969. COUNT(CASE WHEN a.award_level = 4 THEN 1 END) AS third_awards,
  970. COUNT(CASE WHEN a.award_level = 5 THEN 1 END) AS excellent_awards,
  971. SUM(a.points) AS total_points,
  972. SUM(a.bonus_amount) AS total_bonus
  973. FROM competitions c
  974. LEFT JOIN awards a ON c.id = a.competition_id AND a.audit_status = 1
  975. GROUP BY c.id;
  976. -- 实验室设备使用统计视图
  977. CREATE VIEW v_lab_equipment_usage AS
  978. SELECT
  979. l.id AS lab_id,
  980. l.name AS lab_name,
  981. l.lab_code,
  982. COUNT(e.id) AS total_equipment,
  983. COUNT(CASE WHEN e.status = 1 THEN 1 END) AS normal_equipment,
  984. COUNT(CASE WHEN e.status = 2 THEN 1 END) AS fault_equipment,
  985. COUNT(CASE WHEN e.usage_status = 1 THEN 1 END) AS in_use_equipment,
  986. COUNT(eb.id) AS total_borrowings,
  987. COUNT(CASE WHEN eb.borrowing_status = 3 THEN 1 END) AS current_borrowings,
  988. AVG(eb.rating) AS avg_rating
  989. FROM laboratories l
  990. LEFT JOIN equipment e ON l.id = e.lab_id
  991. LEFT JOIN equipment_borrowings eb ON e.id = eb.equipment_id
  992. GROUP BY l.id;
  993. -- =====================================================
  994. -- 10. 存储过程
  995. -- =====================================================
  996. DELIMITER //
  997. -- 自动计算项目进度的存储过程
  998. CREATE PROCEDURE UpdateProjectProgress(IN project_id BIGINT)
  999. BEGIN
  1000. DECLARE total_tasks INT DEFAULT 0;
  1001. DECLARE completed_tasks INT DEFAULT 0;
  1002. DECLARE progress_percentage DECIMAL(5,2) DEFAULT 0;
  1003. -- 计算任务总数和完成数
  1004. SELECT COUNT(*), COUNT(CASE WHEN task_status = 4 THEN 1 END)
  1005. INTO total_tasks, completed_tasks
  1006. FROM project_tasks
  1007. WHERE project_id = project_id;
  1008. -- 计算进度百分比
  1009. IF total_tasks > 0 THEN
  1010. SET progress_percentage = (completed_tasks / total_tasks) * 100;
  1011. END IF;
  1012. -- 更新项目进度
  1013. UPDATE projects
  1014. SET progress_percentage = progress_percentage,
  1015. updated_at = CURRENT_TIMESTAMP
  1016. WHERE id = project_id;
  1017. END //
  1018. -- 发送通知的存储过程
  1019. CREATE PROCEDURE SendNotification(
  1020. IN p_title VARCHAR(200),
  1021. IN p_content TEXT,
  1022. IN p_notification_type TINYINT,
  1023. IN p_sender_id BIGINT,
  1024. IN p_receiver_id BIGINT,
  1025. IN p_business_type VARCHAR(50),
  1026. IN p_business_id BIGINT,
  1027. IN p_priority TINYINT
  1028. )
  1029. BEGIN
  1030. INSERT INTO notifications (
  1031. title, content, notification_type, sender_id, receiver_id,
  1032. business_type, business_id, priority
  1033. ) VALUES (
  1034. p_title, p_content, p_notification_type, p_sender_id, p_receiver_id,
  1035. p_business_type, p_business_id, p_priority
  1036. );
  1037. END //
  1038. DELIMITER ;
  1039. -- =====================================================
  1040. -- 11. 触发器
  1041. -- =====================================================
  1042. -- 项目成员变更时更新项目统计
  1043. DELIMITER //
  1044. CREATE TRIGGER tr_project_member_update
  1045. AFTER INSERT ON project_members
  1046. FOR EACH ROW
  1047. BEGIN
  1048. UPDATE projects
  1049. SET updated_at = CURRENT_TIMESTAMP
  1050. WHERE id = NEW.project_id;
  1051. END //
  1052. -- 任务状态变更时自动更新项目进度
  1053. CREATE TRIGGER tr_task_status_update
  1054. AFTER UPDATE ON project_tasks
  1055. FOR EACH ROW
  1056. BEGIN
  1057. IF OLD.task_status != NEW.task_status THEN
  1058. CALL UpdateProjectProgress(NEW.project_id);
  1059. END IF;
  1060. END //
  1061. -- 设备借用状态变更时更新设备状态
  1062. CREATE TRIGGER tr_equipment_borrowing_update
  1063. AFTER UPDATE ON equipment_borrowings
  1064. FOR EACH ROW
  1065. BEGIN
  1066. IF OLD.borrowing_status != NEW.borrowing_status THEN
  1067. IF NEW.borrowing_status = 3 THEN -- 使用中
  1068. UPDATE equipment SET usage_status = 1 WHERE id = NEW.equipment_id;
  1069. ELSEIF NEW.borrowing_status = 4 THEN -- 已归还
  1070. UPDATE equipment SET usage_status = 0 WHERE id = NEW.equipment_id;
  1071. END IF;
  1072. END IF;
  1073. END //
  1074. DELIMITER ;
  1075. -- =====================================================
  1076. -- 12. 索引优化建议
  1077. -- =====================================================
  1078. -- 复合索引优化
  1079. CREATE INDEX idx_awards_competition_level_date ON awards(competition_id, award_level, award_date);
  1080. CREATE INDEX idx_projects_status_teacher_date ON projects(project_status, teacher_id, start_date);
  1081. CREATE INDEX idx_equipment_lab_status_type ON equipment(lab_id, status, equipment_type);
  1082. CREATE INDEX idx_borrowings_equipment_status_date ON equipment_borrowings(equipment_id, borrowing_status, planned_start_time);
  1083. CREATE INDEX idx_tasks_project_status_assignee ON project_tasks(project_id, task_status, assignee_id);
  1084. CREATE INDEX idx_notifications_receiver_read_type ON notifications(receiver_id, is_read, notification_type);
  1085. -- =====================================================
  1086. -- 数据库设计文档完成
  1087. -- 版本: v1.0
  1088. -- 最后更新: 2024年
  1089. -- =====================================================