一、表的加法:union
data:image/s3,"s3://crabby-images/5ff8d/5ff8d252d83c5b8ea4e5fe071926959d2c960897" alt="SQL多表查询"
data:image/s3,"s3://crabby-images/efe8c/efe8ce9c8b3677a31a66fc0934cc584de2f4debd" alt="SQL多表查询"
如果想保留两个表中的重复值,那么使用union all,那么重复值语文课程就被保留下来了
data:image/s3,"s3://crabby-images/099f7/099f7cfd6e65b0026fc8fe431744cd7e6ae317cf" alt="SQL多表查询"
data:image/s3,"s3://crabby-images/f953c/f953c2ff943b30267d3811cf5f3d115275e8d21b" alt="SQL多表查询"
二、表的联结
- 交叉联结(也叫笛卡尔积 cross jion)
表中的每一行与另一个表中的每一行合并在一起,产生的行数是两个表行数的乘积,它的数据产生如下图所示
data:image/s3,"s3://crabby-images/b222f/b222f995da0104410d795700c04512d887ea382f" alt="SQL多表查询"
2.内联结(inner join):查找出同时存在于两张表的数据
data:image/s3,"s3://crabby-images/5a5b4/5a5b47a50ca0019f1e5f5952ac5f94a105a2a45d" alt="SQL多表查询"
data:image/s3,"s3://crabby-images/f7371/f7371fb5172a06a2345d4a92999a29f7eb40978e" alt="SQL多表查询"
3.左联结(left join):取出左边表的全部数据,右边的表选出与左边相同数据的行,然后进行数据合并
data:image/s3,"s3://crabby-images/2a2af/2a2afe1837d8ac93466beebf6aa60f149ae5dea5" alt="SQL多表查询"
data:image/s3,"s3://crabby-images/3edb9/3edb9061c8c99fbdcc121ba235416ff2caae6698" alt="SQL多表查询"
如果我想查找在左表中有而在右表中没有的数据
data:image/s3,"s3://crabby-images/47c43/47c439e0810b2f7476394845f0c499b3ba43a101" alt="SQL多表查询"
data:image/s3,"s3://crabby-images/6f19d/6f19d08a48cb0e2f85f4f14c4d40269a3e78a973" alt="SQL多表查询"
4、右联结
data:image/s3,"s3://crabby-images/03e87/03e87e3dee440616e928595a9afafc69d331c77d" alt="SQL多表查询"
data:image/s3,"s3://crabby-images/651b7/651b7d5b965288dbbf3ec328ede5ab3f9b437b7c" alt="SQL多表查询"
如果我想查找在右表中有而在左表中没有的数据
data:image/s3,"s3://crabby-images/18be1/18be1d928d21b81d132b9ebfb14fbd35084b8fa7" alt="SQL多表查询"
data:image/s3,"s3://crabby-images/82c6c/82c6c0d1a6e46de14c67c98fafb78c0b5bfd8d28" alt="SQL多表查询"
5、全联结(full join)—取出左表和右表的所有数据,有相同数据就合并,没有则用Null来填充
- MySQL是不支持全联结的
总结:
data:image/s3,"s3://crabby-images/4fca1/4fca1e9659895d8a64b050226e9accf702b9f7ba" alt="SQL多表查询"
三、案例应用
data:image/s3,"s3://crabby-images/17d84/17d8428332a2fa0293810e8a7e135e6bbec3e89f" alt="SQL多表查询"
data:image/s3,"s3://crabby-images/5adbc/5adbc8818930a67012ae549b249ed403063e5f99" alt="SQL多表查询"
data:image/s3,"s3://crabby-images/89aef/89aefed1fdeb3f3ba99d0a2067a4f636970ba12c" alt="SQL多表查询"
data:image/s3,"s3://crabby-images/1e68b/1e68b31411c00d9970565b3e19eea8ca2391945e" alt="SQL多表查询"
四、case表达式—相当于条件判断函数
data:image/s3,"s3://crabby-images/c6c1c/c6c1c890f2a4eaad367e61733ab213267811ac70" alt="SQL多表查询"
案例1.查询score表中学生的成绩是否及格
data:image/s3,"s3://crabby-images/a671d/a671d1a9f551ee3715fa5eadfd779cab1825ec52" alt="SQL多表查询"
案例2.查询每门课程的及格人数和不及格人数
data:image/s3,"s3://crabby-images/251d4/251d46d15c6ddc345bbf374e056a4bae078f4f8f" alt="SQL多表查询"
案例3.使用分段[100-85],[85-70][70-60],[<60]来统计各分段人数,课程号,课程名称
data:image/s3,"s3://crabby-images/0ee5e/0ee5e69e12dc50f742a61f3f86e0c59bb474d077" alt="SQL多表查询"