一、实验目的:
表连接–进行多表查询
二、实验内容:
对MYSQL基础上机练习题(二)中所输入的数据连接表查询
三、题目:
- 使用连接谓词
(1)进行等值连接,查询全部员工的个人信息以及薪酬情况
(2)进行自然连接,查询全部员工的个人信息以及薪酬情况
(3) 查询工资水平在2500以上的员工号、姓名、教育、收入、支出、盈余
(4)查询工资水平在2500以上的员工号、姓名、教育、收入、支出、盈余、所属部门 - 使用JOIN连接
(1)进行等值连接,查询全部员工的个人信息以及薪酬情况
(2)进行自然连接,查询全部员工的个人信息以及薪酬情况
(3) 查询工资水平在2500以上的员工号、姓名、教育、收入、支出、盈余
(4)查询工资水平在2500以上的员工号、姓名、教育、收入、支出、盈余、所属部门
(5)查询所有员工的员工号,名字,薪酬,支出(左连接)
(6)查询所有部门的员工情况(右连接)
(7)查询所有部门的所有员工的薪酬情况(全连接)
(8)查询所有部门所有员工的名字
四、代码:
- 使用连接谓词
(1)进行等值连接,查询全部员工的个人信息以及薪酬情况
等值连接就是把两个表中有对应的行列示,对应第二大题第(1)小题的方式,出现的结果都一样
SELECT * FROM Employees, Salary
WHERE Employees.EmployeeID = Salary.EmployeeID
在这种等值连接的情况下,两个表的相同列名会同时出现
(2)进行自然连接,查询全部员工的个人信息以及薪酬情况
自然连接的情况下,两个表的相同列名不会同时出现,因此使用连接谓词时要选择性地选择列名,对应第二大题第(2)小题的方式,使用JOIN会使代码更简洁
SELECT Employees.*, InCome, OutCome, ActInCome
FROM Employees, Salary
WHERE Employees.EmployeeID = Salary.EmployeeID
(3) 查询工资水平在2500以上的员工号、姓名、教育、收入、支出、盈余
使