mysql多表连接查询实例讲解
作者:laozhang 时间:2024-01-20 09:53:40
实际的项目,存在多张表的关联关系。不可能在一张表里面就能检索出所有数据。如果没有表连接的话,那么我们就需要非常多的操作。比如需要从A表找出限制性的条件来从B表中检索数据。不但需要分多表来操作,而且效率也不高。比如书中的例子:
代码如下:
SELECT FId
FROM T_Customer
WHERE FName='MIKE'
这个SQL语句返回2,也就是姓名为MIKE 的客户的FId值为2,这样就可以到T_Order中检索FCustomerId等于2 的记录:
代码如下:
SELECT FNumber,FPrice
FROM T_Order
WHERE FCustomerId=2
下面我们详细来看看表连接。表连接有多种不同的类型,有交叉连接(CROSS JOIN)、内连接(INNER JOIN)、外连接(OUTTER JOIN)。
(1)内连接(INNER JOIN):内连接组合两张表,并且只获取满足两表连接条件的数据。
代码如下:
SELECT o.FId,o.FNumber,o.FPrice,
c.FId,c.FName,c .FAge
FROM T_Order o JOIN T_Customer c
ON o.FCustomerId= c.FId
注:在大多数数据库系统中,INNER JOIN中的INNER是可选的,INNER JOIN 是默认的连接方式。
在使用表连接的时候可以不局限于只连接两张表,因为有很多情况下需要联系许多表。例如,T_Order表同时还需要连接T_Customer和T_OrderType两张表才能检索到所需要的信息,编写如下SQL语句即可:
代码如下:
SELECT o.FId,o.FNumber,o.FPrice,
c.FId,c.FName,c .FAge
FROM T_Order o JOIN T_Customer c
ON o.FCustomerId= c.FId
INNER JOIN T_OrderType
ON T_Order.FTypeId= T_OrderType.FId
(2)交叉连接(CROSS JOIN):交叉连接所有涉及的表中的所有记录都包含在结果集中。可以采用两种方式来定义交叉连接,分别是隐式和显式的连接。
下面看看隐式的例子:
代码如下:
SELECT T_Customer.FId, T_Customer.FName, T_Customer.FAge,
T_Order.FId, T_Order.FNumber, T_Order.FPrice
FROM T_Customer, T_Order
使用显式的连接则需要使用CROSS JOIN,例子如下:
代码如下:
SELECT T_Customer.FId, T_Customer.FName, T_Customer.FAge,
T_Order.FId, T_Order.FNumber, T_Order.FPrice
FROM T_Customer
CROSS JOIN T_Order
(3)外连接(OUTTER JOIN):内部连接只获取满足连接条件的数据,而对于外部连接来说,主要是解决这样的一种场景。满足条件的数据检索出来,这个没有疑问,外部连接还会检索另一部分数据,那就是将不满足条件的数据以NULL来填充。先来看一下外连接的分类:左外部连接(LEFT OUTER JOIN)、右外部连接(RIGHT OUTER JOIN)和全外部连接(FULLOUTER JOIN)。
I、左外部连接(LEFT OUTER JOIN):前头也说了,将不满足条件的数据以NULL来填充。那么具体是哪些需要以NULL来填充呢,对于左外连接来说的话,连接条件当中,如果出现满足条件的左表的数据在右表中没有相应匹配时,需要把相应的右表字段填充NULL值。也就是说左外部连接的主体是左表,右表来配合。
代码如下:
SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
LEFT OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId
注:如果使用左外部连接的话,通过where语句能过滤其中不符合的数据
代码如下:
SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
LEFT OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId
WHERE o.FPrice>=150
II、右外部连接(RIGHT OUTER JOIN):右外部连接与左外连部接相反,将会被填充NULL值的是左表的字段。也就是说右外部连接的主体是右表,左表来配合。
代码如下:
SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
RIGHT OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId
注:同左外连接一样,可以使用where语句进行过滤
III、全外部连接(FULLOUTER JOIN):全外部连接是左外部连接和右外部连接的合集。也就是既包括左外部连接的结果集,也包括右外部连接的结果集。
代码如下:
SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
FULL OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId
其结果相当于:
SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
LEFT OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId
UNION
SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge
FROM T_Order o
RIGHT OUTER JOIN T_Customer c
ON o.FCustomerId=c.FId
多表查询的多种sql写法:(下面是从两个表里查询<也可以看成从三个表里查询>,显示表v_goods里的所有字段,显示admin2表里的name字段作为添加人,显示表admin2表的name字段作为操作人) 多个表的查询都可按照下面三个例句进行编写sql
SELECT v.*,(SELECT a.name FROM admin2 a WHERE a.adminId=v.loadInId) AS aname,(SELECT a.name FROM admin2 a WHERE a.adminId=v.operatorId) AS uname FROM v_goods v where 1=1;
SELECT v.*,a.name aname,b.name uname FROM v_goods v,admin2 a,admin2 b WHERE a.adminId=v.loadInId AND b.adminId=v.operatorId ;
SELECT v.*,a.name aname,b.name uname FROM v_goods v LEFT JOIN admin2 a ON a.adminId=v.loadInId LEFT JOIN admin2 b ON b.adminId=v.operatorId ;
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
python中内置库os与sys模块的详细介绍
![](https://img.aspxhome.com/file/2023/5/76835_0s.png)
python数字图像处理图像的绘制详解
![](https://img.aspxhome.com/file/2023/9/134969_0s.png)
python 执行shell命令并将结果保存的实例
sql exist的妙用
[hta]一个定时重启或关闭计算机的小工具
![](https://img.aspxhome.com/file/UploadPic/200710/17/20071017123221194s.jpg)
Python OpenCV绘制各类几何图形详解
![](https://img.aspxhome.com/file/2023/2/104992_0s.png)
详解Python中的Numpy、SciPy、MatPlotLib安装与配置
![](https://img.aspxhome.com/file/2023/5/124955_0s.png)
什么是好的设计
9种使用Chrome Firefox 自带调试工具调试javascript技巧
![](https://img.aspxhome.com/file/2023/5/55895_0s.jpg)
Python打印特殊符号及对应编码解析
![](https://img.aspxhome.com/file/2023/8/67388_0s.png)
OpenCV-Python使用分水岭算法实现图像的分割与提取
![](https://img.aspxhome.com/file/2023/5/135275_0s.png)
Selenium常见八大定位法总结
![](https://img.aspxhome.com/file/2023/2/121642_0s.png)
基于Python实现RLE格式分割标注文件的格式转换
![](https://img.aspxhome.com/file/2023/5/87935_0s.png)
详解Python中的GIL(全局解释器锁)详解及解决GIL的几种方案
![](https://img.aspxhome.com/file/2023/1/114791_0s.jpg)
解决py2exe打包后,总是多显示一个DOS黑色窗口的问题
python3 通过 pybind11 使用Eigen加速代码的步骤详解
![](https://img.aspxhome.com/file/2023/7/80497_0s.png)
MySQL 索引和数据表该如何维护
![](https://img.aspxhome.com/file/2023/6/109796_0s.png)
python算法题 链表反转详解
![](https://img.aspxhome.com/file/2023/1/92201_0s.jpg)