mysql连接查询示意图(mysql连接查询左连接)
一、mysql常用连接mysql> select * from name_address;,我来为大家讲解一下关于mysql连接查询示意图?跟着小编一起来看一看吧!
mysql连接查询示意图
一、mysql常用连接
- INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。
- LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。
- RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。
mysql> select * from name_address;
---------- ------ ----
| address | name | id |
---------- ------ ----
| 西北一路 | 张三 | 1 |
| 西北二路 | 李四 | 2 |
| 西北三路 | 王五 | 3 |
---------- ------ ----
3 rows in set
mysql> select * from name_age;
----- -------- ----
| age | name | id |
----- -------- ----
| 18 | 张三 | 1 |
| 20 | 王五 | 2 |
| 21 | 路人甲 | 3 |
----- -------- ----
3 rows in set
1、INNER JOIN
INNER JOIN与一般的连表查询一致,即使用逗号隔开的查询方式。
mysql> SELECT a.`name`,a.age,b.address FROM name_age a INNER JOIN name_address b WHERE(on) a.`name`=b.`name`;
------ ----- ----------
| name | age | address |
------ ----- ----------
| 张三 | 18 | 西北一路 |
| 王五 | 20 | 西北三路 |
------ ----- ----------
2 rows in set
2、LEFT JOIN
以左边的数据表为准
mysql> SELECT a.`name`,a.age,b.address FROM name_age a left JOIN name_address b on
a.`name`=b.`name`;
-------- ----- ----------
| name | age | address |
-------- ----- ----------
| 张三 | 18 | 西北一路 |
| 王五 | 20 | 西北三路 |
| 路人甲 | 21 | NULL |
-------- ----- ----------
3 rows in set
3、RIGHT JOIN
与LEFT JOIN相反,即以右边的数据为准
mysql> SELECT b.`name`,a.age,b.address FROM name_age a right JOIN name_address b on a.`name`=b.`name`;
------ ------ ----------
| name | age | address |
------ ------ ----------
| 张三 | 18 | 西北一路 |
| 王五 | 20 | 西北三路 |
| 李四 | NULL | 西北二路 |
------ ------ ----------
3 rows in set
,免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com