mysql多表查询

多表查询的分类

  • 等值连接 vs 非等值连接
  • 自连接 vs 非自连接
  • 内连接 vs 外连接

内连接查询

  • 如果查询语句中出现了多个表中都存在的字段,则必须指明此字段所在的表。
  • 建议:从sql优化的角度,建议多表查询时,每个字段前都指明其所在的表。
  • 可以给表起别名,在SELECT和WHERE中使用表的别名。
  • 如果给表起了别名,一旦在SELECT或WHERE中使用表名的话,则必须使用表的别名,而不能再使用表的原名。
select book_name,publish_no from book,orsttb04 where book.serial_no = orsttb04.serial_no

非等值连接查询

select aa.publisher no,bb.book name from orsttb04 aa,book bb where bb.price>100

内连接 vs 外连接

内连接

合并具有同一列的两个以上的表的行,结果集中不包含一个表与另一个表不匹配的行

外连接

合并具有同一列的两个以上的表的行,结果集中除了包含一个表与另一个表匹配的行之外, 还查询到了左表或右表中不匹配的行。
外连接的分类:左外连接、右外连接、满外连接

  • 左外连接:两个表在连接过程中除了返回满足连接条件的行以外还返回左表中不满足条件的行,这种连接称为左外连接
  • 右外连接:两个表在连接过程中除了返回满足连接条件的行以外还返回右表中不满足条件的行,这种连接称为右外连接
  • SQL99语法中使用JOIN...ON的方式实现多表的查询。这种方式也能解决外连接的问题。
    • SQL99语法实现内连接(select xx from 表1 inner join 表2 on 条件)
    • SQL99语法实现左外连接(select xx from 表1 left join 表2 on 条件)
    • SQL99语法实现右外连接(select xx from 表1 right join 表2 on 条件)
  • UNION操作符
    • UNION操作符返回两个查询的结果集的并集,去除重复记录。
  • UNION ALL操作符
    • UNION ALL操作符返回两个查询的结果集的并集。对于两个结果集的重复部分,不去重。
  • NATURAL JOIN:它会帮你自动查询两张连接表中所有相同的字段,然后进行等值连接
  • 你能看出与自然连接NATURAL JOIN不同的是,USING指定了具体的相同的字段名称,你需要在USING的括号(O 中填入要指定的同名字段。同时使用JOIN…USING可以简化JOIN ON的等值连接。它与下面的SQL查询结果是相同的:

7种SQl JOIN的实现

你可能感兴趣的:(SQL学习,mysql,数据库,sql)