stastic.sql 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  1. -- 创建数据库
  2. CREATE DATABASE IF NOT EXISTS recruitment_system;
  3. USE recruitment_system;
  4. -- 职位表
  5. CREATE TABLE jobs (
  6. id INT PRIMARY KEY AUTO_INCREMENT,
  7. title VARCHAR(100) NOT NULL,
  8. department VARCHAR(50) NOT NULL,
  9. location VARCHAR(50) NOT NULL,
  10. description TEXT,
  11. status ENUM('active', 'paused', 'draft') NOT NULL DEFAULT 'draft',
  12. pending_resumes INT NOT NULL DEFAULT 0,
  13. passed_resumes INT NOT NULL DEFAULT 0,
  14. ai_criteria JSON,
  15. created_at DATETIME NOT NULL,
  16. updated_at DATETIME NOT NULL,
  17. INDEX idx_status (status),
  18. INDEX idx_location (location),
  19. INDEX idx_department (department)
  20. );
  21. -- 候选人表
  22. CREATE TABLE candidates (
  23. id INT PRIMARY KEY AUTO_INCREMENT,
  24. name VARCHAR(50) NOT NULL,
  25. job_id INT NOT NULL,
  26. job_title VARCHAR(100) NOT NULL,
  27. match_score INT NOT NULL,
  28. status ENUM('pending', 'passed', 'rejected', 'interviewed') NOT NULL DEFAULT 'pending',
  29. highlights TEXT,
  30. concerns TEXT,
  31. summary TEXT,
  32. resume_text TEXT NOT NULL,
  33. education VARCHAR(255),
  34. experience TEXT,
  35. skills TEXT,
  36. submitted_at DATETIME NOT NULL,
  37. reviewed_at DATETIME,
  38. FOREIGN KEY (job_id) REFERENCES jobs(id) ON DELETE CASCADE,
  39. INDEX idx_job_id (job_id),
  40. INDEX idx_status (status),
  41. INDEX idx_match_score (match_score)
  42. );
  43. -- 面试表
  44. CREATE TABLE interviews (
  45. id INT PRIMARY KEY AUTO_INCREMENT,
  46. title VARCHAR(100) NOT NULL,
  47. description TEXT,
  48. questions TEXT,
  49. duration INT NOT NULL,
  50. created_at DATETIME NOT NULL,
  51. INDEX idx_title (title)
  52. );
  53. -- 候选人-面试关联表
  54. CREATE TABLE candidate_interviews (
  55. id INT PRIMARY KEY AUTO_INCREMENT,
  56. candidate_id INT NOT NULL,
  57. interview_id INT NOT NULL,
  58. interview_time DATETIME NOT NULL,
  59. interviewer_id VARCHAR(36),
  60. notes TEXT,
  61. result ENUM('scheduled', 'in_progress', 'completed', 'cancelled') NOT NULL DEFAULT 'scheduled',
  62. FOREIGN KEY (candidate_id) REFERENCES candidates(id) ON DELETE CASCADE,
  63. FOREIGN KEY (interview_id) REFERENCES interviews(id) ON DELETE CASCADE,
  64. UNIQUE INDEX idx_candidate_interview (candidate_id, interview_id),
  65. INDEX idx_result (result),
  66. INDEX idx_interview_time (interview_time)
  67. );
  68. -- 技能表
  69. CREATE TABLE skills (
  70. id INT PRIMARY KEY AUTO_INCREMENT,
  71. name VARCHAR(50) NOT NULL UNIQUE,
  72. category VARCHAR(50),
  73. created_at DATETIME NOT NULL
  74. );
  75. -- 候选人技能关联表
  76. CREATE TABLE candidate_skills (
  77. candidate_id INT NOT NULL,
  78. skill_id INT NOT NULL,
  79. proficiency ENUM('basic', 'intermediate', 'advanced') DEFAULT 'intermediate',
  80. PRIMARY KEY (candidate_id, skill_id),
  81. FOREIGN KEY (candidate_id) REFERENCES candidates(id) ON DELETE CASCADE,
  82. FOREIGN KEY (skill_id) REFERENCES skills(id) ON DELETE CASCADE
  83. );
  84. -- 候选人状态历史表
  85. CREATE TABLE candidate_status_history (
  86. id INT PRIMARY KEY AUTO_INCREMENT,
  87. candidate_id INT NOT NULL,
  88. old_status ENUM('pending', 'passed', 'rejected', 'interviewed') NOT NULL,
  89. new_status ENUM('pending', 'passed', 'rejected', 'interviewed') NOT NULL,
  90. changed_by VARCHAR(50) NOT NULL,
  91. change_reason TEXT,
  92. change_time DATETIME NOT NULL,
  93. FOREIGN KEY (candidate_id) REFERENCES candidates(id) ON DELETE CASCADE,
  94. INDEX idx_candidate_id (candidate_id),
  95. INDEX idx_change_time (change_time)
  96. );
  97. -- 职位状态历史表
  98. CREATE TABLE job_status_history (
  99. id INT PRIMARY KEY AUTO_INCREMENT,
  100. job_id INT NOT NULL,
  101. old_status ENUM('active', 'paused', 'draft') NOT NULL,
  102. new_status ENUM('active', 'paused', 'draft') NOT NULL,
  103. changed_by VARCHAR(50) NOT NULL,
  104. change_time DATETIME NOT NULL,
  105. FOREIGN KEY (job_id) REFERENCES jobs(id) ON DELETE CASCADE,
  106. INDEX idx_job_id (job_id),
  107. INDEX idx_change_time (change_time)
  108. );
  109. -- 用户表
  110. CREATE TABLE users (
  111. id INT PRIMARY KEY AUTO_INCREMENT,
  112. username VARCHAR(50) NOT NULL UNIQUE,
  113. password_hash VARCHAR(100) NOT NULL,
  114. email VARCHAR(100) NOT NULL UNIQUE,
  115. full_name VARCHAR(100),
  116. department VARCHAR(50),
  117. role ENUM('admin', 'recruiter', 'interviewer', 'viewer') NOT NULL DEFAULT 'viewer',
  118. created_at DATETIME NOT NULL,
  119. last_login_at DATETIME,
  120. INDEX idx_username (username),
  121. INDEX idx_role (role)
  122. );
  123. -- 系统配置表
  124. CREATE TABLE system_config (
  125. id INT PRIMARY KEY AUTO_INCREMENT,
  126. config_key VARCHAR(50) NOT NULL UNIQUE,
  127. config_value TEXT,
  128. description VARCHAR(255),
  129. created_at DATETIME NOT NULL,
  130. updated_at DATETIME NOT NULL
  131. );
  132. -- 插入示例数据 - 技能表
  133. INSERT INTO skills (name, category, created_at) VALUES
  134. ('Vue.js', '前端开发', NOW()),
  135. ('React', '前端开发', NOW()),
  136. ('TypeScript', '编程语言', NOW()),
  137. ('JavaScript', '编程语言', NOW()),
  138. ('HTML5', '前端开发', NOW()),
  139. ('CSS3', '前端开发', NOW()),
  140. ('Java', '后端开发', NOW()),
  141. ('Spring Boot', '后端框架', NOW()),
  142. ('MySQL', '数据库', NOW()),
  143. ('Redis', '缓存', NOW()),
  144. ('Figma', '设计工具', NOW()),
  145. ('Sketch', '设计工具', NOW()),
  146. ('Adobe Creative Suite', '设计工具', NOW());
  147. -- 插入示例数据 - 用户表
  148. INSERT INTO users (username, password_hash, email, full_name, department, role, created_at) VALUES
  149. ('admin', '$2a$10$92IXUNpkjO0rOQ5byMi.Ye4oKoEa3Ro9llC/.og/at2.uheWG/igi', 'admin@example.com', '系统管理员', '人力资源部', 'admin', NOW()),
  150. ('recruiter1', '$2a$10$92IXUNpkjO0rOQ5byMi.Ye4oKoEa3Ro9llC/.og/at2.uheWG/igi', 'recruiter1@example.com', '招聘专员A', '人力资源部', 'recruiter', NOW()),
  151. ('interviewer1', '$2a$10$92IXUNpkjO0rOQ5byMi.Ye4oKoEa3Ro9llC/.og/at2.uheWG/igi', 'interviewer1@example.com', '面试官A', '技术部', 'interviewer', NOW());
  152. -- 插入示例数据 - 系统配置表
  153. INSERT INTO system_config (config_key, config_value, description, created_at, updated_at) VALUES
  154. ('system_name', '智能招聘系统', '系统名称', NOW(), NOW()),
  155. ('default_ai_score_threshold', '75', 'AI筛选默认分数阈值', NOW(), NOW()),
  156. ('max_interview_duration', '120', '最大面试时长(分钟)', NOW(), NOW());
  157. -- 插入示例数据 - 职位表
  158. INSERT INTO jobs (title, department, location, description, status, pending_resumes, passed_resumes, ai_criteria, created_at, updated_at)
  159. VALUES
  160. ('Vue.js前端工程师', '技术部', '上海', '负责前端产品开发,具备Vue.js、TypeScript等技术栈经验', 'active', 2, 1,
  161. '{"education":{"condition":">=","value":"本科","weight":20},"experience":{"condition":">=","value":"3年","weight":30},"skills":{"condition":"includes","value":"Vue.js,TypeScript","weight":35},"language":{"condition":">=","value":"英语四级","weight":15}}',
  162. '2024-01-15 00:00:00', '2024-01-20 00:00:00'),
  163. ('Java后端工程师', '技术部', '北京', '负责后端服务开发,熟悉Spring Boot、微服务架构', 'active', 1, 1,
  164. '{"education":{"condition":">=","value":"本科","weight":25},"experience":{"condition":">=","value":"5年","weight":35},"skills":{"condition":"includes","value":"Java,Spring Boot,MySQL","weight":30},"language":{"condition":">=","value":"英语四级","weight":10}}',
  165. '2024-01-10 00:00:00', '2024-01-18 00:00:00'),
  166. ('UI/UX设计师', '设计部', '深圳', '负责产品界面和用户体验设计', 'active', 1, 0,
  167. '{"education":{"condition":">=","value":"专科","weight":15},"experience":{"condition":">=","value":"2年","weight":25},"skills":{"condition":"includes","value":"Figma,Sketch,Adobe","weight":45},"language":{"condition":">=","value":"无要求","weight":15}}',
  168. '2024-01-12 00:00:00', '2024-01-19 00:00:00');
  169. -- 插入示例数据 - 候选人表
  170. INSERT INTO candidates (name, job_id, job_title, match_score, status, highlights, concerns, summary, resume_text, education, experience, skills, submitted_at, reviewed_at)
  171. VALUES
  172. ('张小明', 1, 'Vue.js前端工程师', 88, 'pending', '["5年Vue.js开发经验", "熟悉TypeScript", "有大型项目经验", "具备团队协作能力"]', '["缺少移动端开发经验", "团队管理经验不足"]',
  173. '具备扎实的前端技术基础,Vue.js经验丰富,适合高级前端开发岗位。在技术深度和项目经验方面表现出色,但在移动端开发和团队管理方面还有提升空间。',
  174. '张小明,本科学历,计算机科学专业毕业。拥有5年前端开发经验,精通Vue.js、TypeScript等现代前端技术栈。曾在多家互联网公司担任前端工程师,参与过多个大型项目的开发...',
  175. '本科 - 计算机科学与技术', '5年前端开发经验', '["Vue.js", "TypeScript", "JavaScript", "CSS3", "Webpack"]', '2024-01-20 00:00:00', NULL),
  176. ('李小红', 1, 'Vue.js前端工程师', 75, 'pending', '["3年前端开发经验", "熟悉React和Vue.js", "有组件库开发经验"]', '["TypeScript经验较少", "项目规模偏小", "缺少性能优化经验"]',
  177. '前端基础良好,技术栈匹配度较高,有一定成长潜力。在组件化开发方面有实践经验,但在TypeScript和大型项目经验方面需要进一步提升。',
  178. '李小红,本科学历,软件工程专业。3年前端开发经验,熟悉Vue.js和React框架,有组件库开发经验...',
  179. '本科 - 软件工程', '3年前端开发经验', '["Vue.js", "React", "JavaScript", "HTML5", "CSS3"]', '2024-01-19 00:00:00', NULL),
  180. ('王大强', 2, 'Java后端工程师', 92, 'passed', '["8年Java开发经验", "精通Spring Boot", "有微服务架构经验", "熟悉分布式系统"]', '["缺少云原生经验", "团队规模相对较小"]',
  181. '资深Java后端工程师,技术功底扎实,项目经验丰富。在微服务架构和分布式系统方面有深入理解,是团队的技术骨干候选人。',
  182. '王大强,硕士学历,8年Java后端开发经验。精通Spring Boot框架,有丰富的微服务架构设计和实施经验...',
  183. '硕士 - 计算机科学', '8年Java后端开发经验', '["Java", "Spring Boot", "MySQL", "Redis", "Kafka"]', '2024-01-18 00:00:00', '2024-01-19 00:00:00'),
  184. ('陈小美', 3, 'UI/UX设计师', 85, 'interviewed', '["4年UI/UX设计经验", "精通Figma和Sketch", "有B端产品设计经验", "用户体验思维强"]', '["缺少移动端设计经验", "技术理解需要加强"]',
  185. '优秀的UI/UX设计师,设计功底扎实,用户体验意识强。在B端产品设计方面有丰富经验,但在移动端设计和技术理解方面还有提升空间。',
  186. '陈小美,本科学历,视觉传达设计专业。4年UI/UX设计经验,精通各类设计工具,有丰富的B端产品设计经验...',
  187. '本科 - 视觉传达设计', '4年UI/UX设计经验', '["Figma", "Sketch", "Adobe Creative Suite", "Principle", "Axure"]', '2024-01-17 00:00:00', '2024-01-18 00:00:00'),
  188. ('刘小刚', 2, 'Java后端工程师', 65, 'rejected', '["2年Java开发经验", "熟悉Spring框架"]', '["经验不足", "缺少大型项目经验", "技术深度有限", "沟通能力待提升"]',
  189. '初级Java开发工程师,基础技能掌握良好,但经验和技术深度不足以满足当前岗位要求。建议继续积累项目经验后再申请。',
  190. '刘小刚,专科学历,2年Java开发经验。熟悉Spring框架,参与过小型项目开发...',
  191. '专科 - 计算机应用技术', '2年Java开发经验', '["Java", "Spring", "MySQL", "HTML", "CSS"]', '2024-01-16 00:00:00', '2024-01-17 00:00:00');
  192. -- 插入示例数据 - 候选人技能关联表
  193. INSERT INTO candidate_skills (candidate_id, skill_id, proficiency) VALUES
  194. (1, 1, 'advanced'), -- Vue.js
  195. (1, 3, 'advanced'), -- TypeScript
  196. (1, 4, 'advanced'), -- JavaScript
  197. (1, 5, 'intermediate'), -- HTML5
  198. (1, 6, 'intermediate'), -- CSS3
  199. (2, 1, 'intermediate'), -- Vue.js
  200. (2, 2, 'intermediate'), -- React
  201. (2, 4, 'advanced'), -- JavaScript
  202. (3, 7, 'advanced'), -- Java
  203. (3, 8, 'advanced'), -- Spring Boot
  204. (3, 9, 'intermediate'), -- MySQL
  205. (3, 10, 'intermediate'), -- Redis
  206. (4, 11, 'advanced'), -- Figma
  207. (4, 12, 'advanced'), -- Sketch
  208. (4, 13, 'intermediate'), -- Adobe Creative Suite
  209. (5, 7, 'intermediate'), -- Java
  210. (5, 8, 'basic'), -- Spring Boot
  211. (5, 9, 'intermediate'); -- MySQL
  212. -- 插入示例数据 - 面试表
  213. INSERT INTO interviews (title, description, questions, duration, created_at)
  214. VALUES
  215. ('Vue.js前端工程师初面', '主要考察前端基础知识和Vue.js技术栈',
  216. '["Vue 3的Composition API相比Options API有什么优势?", "请解释Vue的响应式原理", "如何优化Vue应用的性能?", "描述一个你负责的复杂前端项目"]',
  217. 60, '2024-01-15 00:00:00'),
  218. ('Java后端工程师技术面试', '重点考察Java技术栈和系统设计能力',
  219. '["Spring Boot的自动配置原理是什么?", "如何设计一个高并发的秒杀系统?", "MySQL的索引优化策略有哪些?", "微服务架构的优缺点是什么?"]',
  220. 90, '2024-01-12 00:00:00'),
  221. ('UI/UX设计师面试', '考察设计理念和项目经验',
  222. '["你如何理解用户体验设计?", "描述一个你参与的成功设计案例", "你常用的设计工具和工作流程是什么?", "如何与开发团队协作实现设计方案?"]',
  223. 45, '2024-01-18 00:00:00');
  224. -- 插入示例数据 - 候选人-面试关联表
  225. INSERT INTO candidate_interviews (candidate_id, interview_id, interview_time, interviewer_id, notes, result)
  226. VALUES
  227. (1, 1, '2024-01-22 10:00:00', '1', '安排在上午10点,面试官:技术部张组长', 'scheduled'),
  228. (3, 2, '2024-01-21 14:30:00', '1', '安排在下午2点半,面试官:技术总监李总', 'scheduled'),
  229. (4, 3, '2024-01-20 16:00:00', '2', '安排在下午4点,面试官:设计部王经理', 'completed');
  230. -- 插入示例数据 - 候选人状态历史表
  231. INSERT INTO candidate_status_history (candidate_id, old_status, new_status, changed_by, change_reason, change_time)
  232. VALUES
  233. (3, 'pending', 'passed', 'recruiter1', 'AI筛选通过,匹配度高', '2024-01-19 09:30:00'),
  234. (4, 'pending', 'interviewed', 'recruiter1', '已完成面试', '2024-01-18 17:30:00'),
  235. (5, 'pending', 'rejected', 'recruiter1', '经验不足,技术深度有限', '2024-01-17 11:45:00');
  236. -- 插入示例数据 - 职位状态历史表
  237. INSERT INTO job_status_history (job_id, old_status, new_status, changed_by, change_time)
  238. VALUES
  239. (1, 'draft', 'active', 'admin', '2024-01-15 09:00:00'),
  240. (2, 'draft', 'active', 'admin', '2024-01-10 14:30:00'),
  241. (3, 'draft', 'active', 'admin', '2024-01-12 11:15:00');