一、子查询
简单的说,子查询就是将一个查询结果嵌套到另一个查询语句中,作为这个查询语句的查询条件或者查询对象。
1.作为查询对象
- 注意:将查询结果作为查询对象时必须要起一个别名
SELECT name FROM (SELECT id, name FROM tableA) tA;
2.作为查询条件
- 注意: 这里假设tableB只存在一条数据,否则需要加上条件来确定唯一name
SELECT * FROM tableA WHERE name = (SELECT name FROM tableB);
二、联表查询
1.交叉链接查询
会出现笛卡尔积现象,一般是不会使用的
SELECT a.name, b.name FROM
2.内连接
SELECT a.name, b.name FROM tableA a, tableB b WHERE a.id = b.id;
SELECT a.name, b.name FROM FROM tableA a INNER JOIN tableB b ON a.id = b.id;
3.左外连接
SELECT a.name, b.name FROM tableA a LEFT JOIN tableB b ON a.id = b.id;
4.右外连接
SELECT a.name, b.name FROM tableA a RIGHT JOIN tableB b ON a.id = b.id;
5.自连接
SELECT a.name, b.name FROM tableA a INNER JOIN tableA b ON a.bossId = b.id;
SELECT a.name, b.name FROM tableA a LEFT JOIN tableA b ON a.bossId = b.id;