HRS_create_and_init.sql 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. -- 创建人力资源管理系统数据库
  2. drop database if exists HRS;
  3. create database HRS default charset utf8;
  4. -- 切换数据库上下文环境
  5. use HRS;
  6. -- 删除表
  7. drop table if exists TbEmp;
  8. drop table if exists TbDept;
  9. -- 创建部门表
  10. create table TbDept
  11. (
  12. deptno tinyint primary key, -- 部门编号
  13. dname varchar(10) not null, -- 部门名称
  14. dloc varchar(20) not null -- 部门所在地
  15. );
  16. -- 添加部门记录
  17. insert into TbDept values (10, '会计部', '北京');
  18. insert into TbDept values (20, '研发部', '成都');
  19. insert into TbDept values (30, '销售部', '重庆');
  20. insert into TbDept values (40, '运维部', '深圳');
  21. -- 创建员工表
  22. create table TbEmp
  23. (
  24. empno int primary key, -- 员工编号
  25. ename varchar(20) not null, -- 员工姓名
  26. job varchar(20) not null, -- 员工职位
  27. mgr int, -- 主管编号
  28. sal int not null, -- 员工月薪
  29. comm int, -- 每月补贴
  30. dno tinyint -- 所在部门编号
  31. );
  32. -- 添加外键约束
  33. alter table TbEmp add constraint fk_dno foreign key (dno) references TbDept(deptno);
  34. -- 添加员工记录
  35. insert into TbEmp values (7800, '张三丰', '总裁', null, 9000, 1200, 20);
  36. insert into TbEmp values (2056, '乔峰', '分析师', 7800, 5000, 1500, 20);
  37. insert into TbEmp values (3088, '李莫愁', '设计师', 2056, 3500, 800, 20);
  38. insert into TbEmp values (3211, '张无忌', '程序员', 2056, 3200, null, 20);
  39. insert into TbEmp values (3233, '丘处机', '程序员', 2056, 3400, null, 20);
  40. insert into TbEmp values (3251, '张翠山', '程序员', 2056, 4000, null, 20);
  41. insert into TbEmp values (5566, '宋远桥', '会计师', 7800, 4000, 1000, 10);
  42. insert into TbEmp values (5234, '郭靖', '出纳', 5566, 2000, null, 10);
  43. insert into TbEmp values (3344, '黄蓉', '销售主管', 7800, 3000, 800, 30);
  44. insert into TbEmp values (1359, '胡一刀', '销售员', 3344, 1800, 200, 30);
  45. insert into TbEmp values (4466, '苗人凤', '销售员', 3344, 2500, null, 30);
  46. insert into TbEmp values (3244, '欧阳锋', '程序员', 3088, 3200, null, 20);
  47. insert into TbEmp values (3577, '杨过', '会计', 5566, 2200, null, 10);
  48. insert into TbEmp values (3588, '朱九真', '会计', 5566, 2500, null, 10);
  49. -- 查询薪资最高的员工姓名和工资
  50. -- 查询员工的姓名和年薪((月薪+补贴)*12)
  51. -- 查询有员工的部门的编号和人数
  52. -- 查询所有部门的名称和人数
  53. -- 查询薪资最高的员工(Boss除外)的姓名和工资
  54. -- 查询薪水超过平均薪水的员工的姓名和工资
  55. -- 查询薪水超过其所在部门平均薪水的员工的姓名、部门编号和工资
  56. -- 查询部门中薪水最高的人姓名、工资和所在部门名称
  57. -- 查询主管的姓名和职位
  58. -- 查询薪资排名4~6名的员工姓名和工资
  59. use HRS;
  60. drop procedure if exists sp_avg_sal_by_dept;
  61. create procedure sp_avg_sal_by_dept(deptno integer, out avg_sal float)
  62. begin
  63. select avg(sal) into avg_sal from TbEmp where dno=deptno;
  64. end;
  65. call sp_avg_sal_by_dept(10, @avgSal);
  66. select @avgSal;