MySQL高级查询---连接查询实例

栏目: 数据库 · 发布时间: 6年前

内容简介:MySQL高级查询---连接查询实例

最近在腾讯课堂学习 Mysql 开发,收获不浅,因此,特地分享高级查询。

使用 sql 查询很简单,很基础的SQLECT语句查询。如果想从多个表查询比较复杂的信息,就会使用高级查询实现。

常见的高级查询包括多连接查询,外连接查询与组合查询等,今天我先学习最常用的连接查询。

我先以一张person表(id,name,phone,age)与一个student表(id,name,sex,qq,email)演示:

person表:

MySQL高级查询---连接查询实例

student表:

MySQL高级查询---连接查询实例

一 内连接(INNER JOIN)

1:等值连接:指使用等号”=”比较两个连接列的值,相当于两表执行迪卡尔后,取两表连接列相等的纪录。

语法:

SELECT 列 FROM 表1 INNER JOIN 表2 ON 表1.列 = 表2.列

示例:

SELECT A.*,B.* FROM person A INNER JOIN student B ON A.id = B.id

结果:

MySQL高级查询---连接查询实例

2:非等值连接:指使用大于号”>” 或小于号”<”比较两个表的连接列的值,相当于两表执行迪卡尔后,取一个表大于或小于另一个表的连接列值的纪录。

语法:

SELECT 列 FROM 表1 INNER JOIN 表2 ON 表1.列 >(<) 表2.列

示例:

SELECT A.*,B.* FROM person A INNER JOIN student B ON A.id > B.id

结果:

MySQL高级查询---连接查询实例

二, 外连接

1,左外连接(LEFT OUTER JOIN):指将左表的所有记录与右表符合条件的记录,返回的结果除内连接的结果,还有左表不符合条件的记录,并在右表相应列中填NULL。

示例: SELECT A. ,B. FROM person A LEFT JOIN student B ON A.id = B.id

结果:

MySQL高级查询---连接查询实例

2:右外连接(RIGHT OUTER JOIN):与左外连接相反,指将右表的所有记录与左表符合条件的记录,返回的结果除内连接的结果,还有右表不符合条件的记录,并在左表相应列中填NULL。

示例: SELECT A. ,B. FROM person A RIGHT JOIN student B ON A.id = B.id

结果:

MySQL高级查询---连接查询实例

3:全外连接(FULL JOIN)——–MySQL不支持:指将左表所有记录与右表所有记录进行连接,返回的结果除内连接的结果,还有左表与右表不符合条件的记录,并在左表与右表相应列中填NULL。

三:自然连接(NATURAL JOIN):指自动将表中相同名称的列进行记录匹配。

示例:

SELECT  A.*,B.*   FROM person A  NATURAL JOIN student B

结果:

MySQL高级查询---连接查询实例

四:自连接:指用表的别名实现表自身的连接。

示例:

SELECT B.* FROM person A,student B WHERE A.id = B.id AND B.age > 15

结果:

MySQL高级查询---连接查询实例


以上所述就是小编给大家介绍的《MySQL高级查询---连接查询实例》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Impractical Python Projects

Impractical Python Projects

Lee Vaughan / No Starch Press / 2018-11 / USD 29.95

Impractical Python Projects picks up where the complete beginner books leave off, expanding on existing concepts and introducing new tools that you’ll use every day. And to keep things interesting, ea......一起来看看 《Impractical Python Projects》 这本书的介绍吧!

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具