连接查询[连表查询、多表查询]
当查询结果的列来源于多张表时,需要将多张表连接成一个大的数据集,再选择合适的列返回
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.sid
where 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.sid
where 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.sid
where b.sid=102;
来源:http://www.icode9.com/content-2-211651.html