欢迎光临
我们一直在努力

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

 收藏 (0) 打赏

您可以选择一种方式赞助本站

支付宝扫一扫赞助

微信钱包扫描赞助

未经允许不得转载:英协网 » mysql连接查询左连接,右连接,内连接实例详解

分享到: 生成海报
avatar

热门文章

  • 评论 抢沙发

    • QQ号
    • 昵称 (必填)
    • 邮箱 (必填)
    • 网址

    登录

    忘记密码 ?

    切换登录

    注册

    我们将发送一封验证邮件至你的邮箱, 请正确填写以完成账号注册和激活