

如下面表格所示,表格里存有每个雇员经理的信息,我们也许需要从这个表里获取两次信息。
SELECT * FROM Employee AS a, Employee AS b

从两个表里使用 Select 语句可能会导致产生 笛卡尔乘积 。在这种情况下,输出会产生 4*4=16 个记录。
笛卡尔乘积是指在数学中,两个集合X和Y的笛卡尔积(Cartesian product),又称直积,表示为X×Y,第一个对象是X的成员而第二个对象是Y的所有可能有序对的其中一个成员 [3] 。
假设集合A={a, b},集合B={0, 1, 2},则两个集合的笛卡尔积为{(a, 0), (a, 1), (a, 2), (b, 0), (b, 1), (b, 2)}。
然而我们只对雇员工资高于经理的人感兴趣。所以我们应该用 WHERE 语句加 2 个判断条件。
- SELECT
- *
- FROM
- Employee AS a,
- Employee AS b
- WHERE
- a.ManagerId = b.Id
- AND a.Salary > b.Salary

由于我们只需要输出雇员的名字,所以我们修改一下上面的代码,得到最终解法:
- SELECT
- a.name AS Employee
- FROM
- Employee AS a,
- Employee AS b
- WHERE
- a.ManagerId = b.Id
- AND a.Salary > b.Salary
或者使用INEER JOIN内连接
- SELECT
- a.NAME AS Employee
- FROM Employee AS a JOIN Employee AS b
- ON a.ManagerId = b.Id
- AND a.Salary > b.Salary