首页 热点资讯 义务教育 高等教育 出国留学 考研考公

Mysql两表联合查询的四种情况总结

发布网友

我来回答

1个回答

热心网友

一般来说,我们为了得到更完整的结果,我们需要从两个或更多的表中获取结果,我一般都是用select
xxx,xxx
from
表1,表2
where
表1.xxx=表2.xxx,我们一般都是进行的是这般的操作,其实mysql中还有一种操作,那就是join的操作,例如底下有两个表:
请看
"Persons"
表:
接下来请看
"Orders"
表:
以上的这两个表,然后我们把它们进行连接查询
SELECT
Persons.LastName,
Persons.FirstName,
Orders.OrderNo
FROM
Persons,
Orders
WHERE
Persons.Id_P
=
Orders.Id_P
结果集:
如果使用关键词JOIN来从两个表中获取数据
SELECT
Persons.LastName,
Persons.FirstName,
Orders.OrderNo
FROM
Persons
INNER
JOIN
Orders
ON
Persons.Id_P
=
Orders.Id_P
ORDER
BY
Persons.LastName
结果集:
则inner
join
与上面的普通查询没有区别
不同的
SQL
JOIN
JOIN:
如果表中有至少一个匹配,则返回行
LEFT
JOIN:
即使右表中没有匹配,也从左表返回所有的行
RIGHT
JOIN:
即使左表中没有匹配,也从右表返回所有的行
FULL
JOIN:
只要其中一个表中存在匹配,就返回行
LEFT
JOIN
关键字语法
"Persons"
表:
"Orders"
表:
SELECT
Persons.LastName,
Persons.FirstName,
Orders.OrderNo
FROM
Persons
LEFT
JOIN
Orders
ON
Persons.Id_P=Orders.Id_P
ORDER
BY
Persons.LastName
结果集:
SQL
RIGHT
JOIN
关键字
"Persons"
表:
"Orders"
表:
SELECT
Persons.LastName,
Persons.FirstName,
Orders.OrderNo
FROM
Persons
RIGHT
JOIN
Orders
ON
Persons.Id_P=Orders.Id_P
ORDER
BY
Persons.LastName
结果集:
SQL
FULL
JOIN
关键字
"Persons"
表:
"Orders"
表:
全连接(FULL
JOIN)实例
SELECT
Persons.LastName,
Persons.FirstName,
Orders.OrderNo
FROM
Persons
FULL
JOIN
Orders
ON
Persons.Id_P=Orders.Id_P
ORDER
BY
Persons.LastName
结果集:
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
您可能感兴趣的文章:浅谈mysql的子查询联合与in的效率详解Mysql多表联合查询效率分析及优化对MySQL几种联合查询的通俗解释Mysql联合查询UNION和UNION
ALL的使用介绍Mysql联合查询UNION和Order
by同时使用报错问题的解决办法mysql多表联合查询返回一张表的内容实现代码mysql使用from与join两表查询的区别总结Mysql查询正在执行的事务以及等待锁的操作方式MySQL查询中LIMIT的大offset导致性能低下浅析Mysql如何查询某条记录在分页的第几页详析

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com