打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
MySql数据库多表操作

连接查询[连表查询、多表查询]

当查询结果的列来源于多张表时,需要将多张表连接成一个大的数据集,再选择合适的列返回

mysql支持三种类型的连接查询,分别为:

内连接查询(inner join)

查询的结果为两个表匹配到的数据

使用内连接,必须保证两个表都会对应id的数据才会被查询出来。

                

 

格式:select 字段1,字段2... from 主表A inner join 从表B on 主表A.主键=从表B.外键

例如:查询学生的信息[ 成绩、名字、班级 ]        我们给学生表添加一个学生信息,然后使用该学生的主键id来连表查询成绩、名字和班级。

insert into student (name,sex,age,class,description) values ('刘德华',1,17,406,'');select achievement,name,class from student as a inner join achievement as b on a.id=b.sidwhere id=101;# 上面语句因位该学生只在学生表student中有数据,而成绩表中没有数据,所以使用内连接,连表查询的结果是Empty set (0.00 sec)

 

同样,如果从表有数据,而主表没有数据,则使用内连接查询一样无法查询到结果。

#例如,添加一个成绩记录,是不存在学生insert into achievement (sid,cid,achievement) values (102,10,85); select achievement,name,class from student as a inner join achievement as b on a.id=b.sidwhere id=102;

右连接查询(right join)

只要从表有数据,不管主表是否有数据,都会查询到结果。[以从表的结果为主 例如:a.id=b.sid,只要b表的sid存在就可以 ;  a.id不存在不要紧  左表中不存在的数据使用null填充]

查询的结果为两个表匹配到的数据,右表特有的数据,对于左表中不存在的数据使用null填充

             

 

格式:select 字段1,字段2... from 主表 right join 从表 on 主表.主键=从表.外键

select achievement,name,class from student as a right join achievement as b on a.id=b.sidwhere b.sid=102;

 

 

来源:http://www.icode9.com/content-2-211651.html
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
mysql从一张表查出数据存到另一张表和inner join的用法
mysql中的内连接,外连接实例详解
聊聊sql优化的15个小技巧,太赞了
Web-第六天 MySQL回顾学习
MySQL百万级、千万级数据多表关联SQL语句调优
【MySQL】多表连接更新(update),使用临时表加快效率
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服