mysql表内连接实例_mysql连接查询左连接,右连接,内连接实例详解

一、mysql常用连接

INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。

LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。

RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。

mysql> select* fromname_address;

+----------+------+----+

| address | name| id |

+----------+------+----+

| 西北一路 | 张三 | 1 |

| 西北二路 | 李四 | 2 |

| 西北三路 | 王五 | 3 |

+----------+------+----+

3 rowsin set

mysql> select* fromname_age;

+-----+--------+----+

| age | name| id |

+-----+--------+----+

| 18 | 张三 | 1 |

| 20 | 王五 | 2 |

| 21 | 路人甲 | 3 |

+-----+--------+----+

3 rowsin set

1、INNER JOIN

INNER JOIN与一般的连表查询一致,即使用逗号隔开的查询方式。

mysql> SELECTa.`name`,a.age,b.address FROMname_age a INNERJOIN name_address b WHERE(on) a.`name`=b.`name`;

+------+-----+----------+

| name| age | address |

+------+-----+----------+

| 张三 | 18 | 西北一路 |

| 王五 | 20 | 西北三路 |

+------+-----+----------+

2 rowsin set

2、LEFT JOIN

以左边的数据表为准

mysql> SELECTa.`name`,a.age,b.address FROMname_age a left JOIN name_address b on

a.`name`=b.`name`;

+--------+-----+----------+

| name| age | address |

+--------+-----+----------+

| 张三 | 18 | 西北一路 |

| 王五 | 20 | 西北三路 |

| 路人甲 | 21 | NULL |

+--------+-----+----------+

3 rowsin set

3、RIGHT JOIN

与LEFT JOIN相反,即以右边的数据为准

mysql> SELECTb.`name`,a.age,b.address FROMname_age a right JOIN name_address b ona.`name`=b.`name`;

+------+------+----------+

| name| age | address |

+------+------+----------+

| 张三 | 18 | 西北一路 |

| 王五 | 20 | 西北三路 |

| 李四 | NULL | 西北二路 |

+------+------+----------+

3 rowsin set

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值