一、mysql常用连接mysql> select * from name_address;,我来为大家讲解一下关于mysql连接查询示意图?跟着小编一起来看一看吧!

mysql连接查询示意图(mysql连接查询左连接)

mysql连接查询示意图

一、mysql常用连接

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 WHEREon) 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

,