day03.sql 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. DROP TABLE IF EXISTS emp;
  2. DROP TABLE IF EXISTS dept;
  3. # 创建部门表
  4. CREATE TABLE dept(
  5. did INT PRIMARY KEY AUTO_INCREMENT,
  6. dname VARCHAR(20)
  7. );
  8. # 创建员工表
  9. CREATE TABLE emp (
  10. id INT PRIMARY KEY AUTO_INCREMENT,
  11. NAME VARCHAR(10),
  12. gender CHAR(1), -- 性别
  13. salary DOUBLE, -- 工资
  14. join_date DATE, -- 入职日期
  15. dep_id INT,
  16. FOREIGN KEY (dep_id) REFERENCES dept(did) -- 外键,关联部门表(部门表的主键)
  17. );
  18. -- 添加部门数据
  19. INSERT INTO dept (dNAME) VALUES ('研发部'),('市场部'),('财务部'),('销售部');
  20. -- 添加员工数据
  21. INSERT INTO emp(NAME,gender,salary,join_date,dep_id) VALUES
  22. ('孙悟空','男',7200,'2013-02-24',1),
  23. ('猪八戒','男',3600,'2010-12-02',2),
  24. ('唐僧','男',9000,'2008-08-08',2),
  25. ('白骨精','女',5000,'2015-10-07',3),
  26. ('蜘蛛精','女',4500,'2011-03-14',1),
  27. ('小白龙','男',2500,'2011-02-14',null);
  28. # 92 标准 笛卡尔乘积 重复数据
  29. select * from dept d , emp e;
  30. # 加条件 连表条件
  31. select * from dept d , emp e where d.did = e.dep_id ;
  32. # 92 标准 内连接 = 92标准
  33. # inner join 连表 条件 on
  34. select * from dept d inner join emp e on d.did = e.dep_id;
  35. # 省略 inner
  36. select * from dept d join emp e on d.did = e.dep_id;
  37. # 99标准 外连接
  38. # 左外连接 left join on 以左表为主 主表的内容全部保留。
  39. select * from emp e left join dept d on d.did = e.dep_id;
  40. # 右外连接 right join on 以右表为主
  41. select * from dept d right join emp e on d.did = e.dep_id;
  42. select * from dept d left join emp e on d.did = e.dep_id;
  43. # 查询工资高于猪八戒的员工信息
  44. # 1.猪八戒工资
  45. # 2. 大于 1 结果。员工信息。
  46. select e.salary from emp e where e.NAME="猪八戒";
  47. select * from emp e where e.salary > (
  48. select e.salary from emp e where e.NAME="猪八戒"
  49. );
  50. #子查询根据查询结果不同,作用不同
  51. /*
  52. * 子查询语句结果是单行单列,子查询语句作为条件值,使用 = != > < 等进行条件判断
  53. * 子查询语句结果是多行单列,子查询语句作为条件值,使用 in 等关键字进行条件判断
  54. * 子查询语句结果是多行多列,子查询语句作为虚拟表 返回是表
  55. */
  56. # 查询 '财务部' 和 '市场部' 所有的员工信息
  57. # 子查询
  58. select did from dept d where d.dname in ( '财务部','市场部');
  59. select * from emp e where e.dep_id in (
  60. select did from dept d where d.dname in ( '财务部','市场部')
  61. )
  62. # 不用子查询
  63. select e.* from emp e join dept d on d.did = e.dep_id where d.dname in ( '财务部','市场部');
  64. # 查询入职日期是 '2011-11-11' 之后的员工信息和部门信息
  65. select * from emp e where e.join_date > '2011-11-11';
  66. select d.dname,e.* from dept d join (
  67. select e.NAME, e.dep_id from emp e where e.join_date > '2011-11-11'
  68. ) e on d.did = e.dep_id;
  69. # 注意 明确字段