连接查询
data:image/s3,"s3://crabby-images/1fc36/1fc36e52929c763f906aaa1f14ff280f65f5fed5" alt=""
举例:
data:image/s3,"s3://crabby-images/7472f/7472f8e6d8b72666eb9ab87ec2515fc298de4e65" alt=""
笛卡尔乘积现象:
select name,boyname from beauty,boys;
data:image/s3,"s3://crabby-images/0020a/0020a757b12ac8cb48abcfc89f88fecb27eb7b0b" alt=""
添加有效的连接条件进行避免:
data:image/s3,"s3://crabby-images/013a4/013a4352b89407485adde4d68b9e2e67926bf392" alt=""
连接查询的分类:
data:image/s3,"s3://crabby-images/20d6d/20d6d7ac16c91e6e62829fe44249b23f470f409c" alt=""
sql92标准(只支持内连接)
等值连接
data:image/s3,"s3://crabby-images/184b7/184b74da393ba2ef272689ed4d866f3bc0688bb5" alt=""
data:image/s3,"s3://crabby-images/efeb5/efeb5606a47ccfa87725012b565fe56fc840d2af" alt=""
为表起别名:提高简洁度,区分多个重名的字段,如果为表起了别名,则查询的字段就不能用原来的表名去限定
data:image/s3,"s3://crabby-images/11147/111470e3ef109fa7ec99ddcd599c8d5407a5ec1f" alt=""
data:image/s3,"s3://crabby-images/b4b8d/b4b8d9bb5e668c6f6d44c0e90b80c1e12934dc87" alt=""
data:image/s3,"s3://crabby-images/0f6ae/0f6aef4c0ea4775a5d061509f2cb493bdd53e130" alt=""
data:image/s3,"s3://crabby-images/e2c01/e2c01a6ad8f3872a48a7805cb86b2dcf8aa945c6" alt=""
data:image/s3,"s3://crabby-images/0a803/0a803631295e156baa228b563f1627c2a872e6f9" alt=""
三表连接案例:
data:image/s3,"s3://crabby-images/7b9fc/7b9fcf201d6a52b394b3e9c995742a65dd82811a" alt=""
非等值连接
data:image/s3,"s3://crabby-images/1d895/1d895b3b864bb3168137560502930ab527b257a6" alt=""
自连接,和自连接的区别是,自己和自己连接(一般是表中有特殊字段才能进行自连接)
案例:
data:image/s3,"s3://crabby-images/b1541/b1541a6f06b32d1d6bdd6e6c862e107670ca5b67" alt=""
data:image/s3,"s3://crabby-images/c0019/c00199bc87818b3a96df2d017b861c8cc0fee3ff" alt=""
sql99标准
语法:
data:image/s3,"s3://crabby-images/1f7a3/1f7a35cf7e466810172cfbe59633c753b3a1af80" alt=""
92和99语法对比:
data:image/s3,"s3://crabby-images/2cd2c/2cd2c3536ef3bf0743f80e8198735b33e6acd9da" alt=""
举例:
data:image/s3,"s3://crabby-images/402b6/402b62e75ec7982e24abc858cb9ec4e35e459d86" alt=""
内连接:
data:image/s3,"s3://crabby-images/bbd3b/bbd3b14e521d9ec79b9c4e612fe6a065b11e68e0" alt=""
-
等值连接:
1.
2.
3.
image.png
特点:
image.png
- 非等值连接
查询员工工资级别个数>20的个数,并且按工资级别降序
SELECT
grade_level,count(*) mount
FROM employees e
join job_grades j
on e.salary between j.lowest_sal and j.highest_sal
GROUP BY grade_level
HAVING mount>20
ORDER BY grade_level DESC
-
自连接
查询员工的上级:
表,将同一张表看作2张表,进行自连接
SELECT
e.last_name 员工名,e.employee_id 员工id,m.last_name 领导名,m.employee_id 领导id
FROM employees e
join employees m
on e.manager_id = m.employee_id
data:image/s3,"s3://crabby-images/7bc98/7bc980d1acebc5301c6783d3cfa6bfbf3228d2f8" alt=""
外连接
应用场景:查询一个表有而另一个表没有的数据时就需要用到外连接了。
data:image/s3,"s3://crabby-images/dfe0d/dfe0d89b0af69e3b82734cce6c447e9ab3a35a1c" alt=""
data:image/s3,"s3://crabby-images/fb23b/fb23b033dfecd91cce596f80a2638e06d6530742" alt=""
-
左右外连接
左连接
右连接
-
全(外)连接
全连接
交叉连接
data:image/s3,"s3://crabby-images/280dd/280ddc7510e4db58d3ba41e47f3e047a60ad62c1" alt=""
连接查询总结
1.以后推荐使用sql99语法,更有优势
data:image/s3,"s3://crabby-images/6ed51/6ed51022fdcd39148cad86cfe28ee8f1d335d6be" alt=""
data:image/s3,"s3://crabby-images/65f5f/65f5f33c50fb00179a53f988f7d1fb1571c90a27" alt=""
data:image/s3,"s3://crabby-images/36298/3629868e81c2bf0e7134fd8a642339f98b3fec91" alt=""
网友评论