mysql基础连接查询

一、mysql常用连接

  • INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。
  • LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。
  • RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
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与一般的连表查询一致,即使用逗号隔开的查询方式。

?
1
2
3
4
5
6
7
8
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 

以左边的数据表为准

?
1
2
3
4
5
6
7
8
9
10
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相反,即以右边的数据为准

?
1
2
3
4
5
6
7
8
9
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

以上就是MySQL 连接查询的资料整理,大家如有疑问可以留言讨论,共同进步,感谢阅读,希望能帮助到大家!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值