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