一:mysql三种链接方式:内链接、左外链接、右外链接。
不知道这种图怎么画,直接找了网上的资料,图片来自此链接。https://www.cnblogs.com/yscec/p/11911075.html
inner join:取用的就是图中红色部分,即表a与表b的交集,其余的都会被舍弃。
left join:左外链接,取用的是上图中a的部分,a有的b没有,则对应的字段为null;a没有的但是b有,也会被舍弃。
right join:右外链接,取用的是上图中b的部分。b有的数据对应到a里面没有,对应的a表的字段为null;b没有的数据但是a有,也会被舍弃。
举个例子
课程表c,学生表s,学生课程成绩表grade。
1:select * from grade inner join c on grade.cId=c.id;
这样得到的结果有6条
分别是
id cid sid score course teacher
1 1 1 90 语文 张三
2 1 3 80 语文 张三
3 1 4 100 语文 张三
4 2 2 99 语文 李四
5 3 5 70 英语 王五
6 5 1 100 计算机 王八
2:左链接的情况
select * from grade left join c on grade.cid = c.id;
这样得到的结果有7条
分别是
id cid sid score course teacher
1 1 1 90 语文 张三
2 1 3 80 语文 张三
3 1 4 100 语文 张三
4 2 2 99 语文 李四
5 3 5 70 英语 王五
6 5 1 100 计算机 王八
7 6 6 99 null null
3:右外链接的情况
select * from grade right join c on grade.cid = c.id;
这样得到的结果有7条
分别是
id course teacher sid score
1 语文 张三 1 90
1 语文 张三 3 80
1 语文 张三 4 100
2 语文 李四 2 99
3 英语 王五 5 70
4 数学 赵七 null null
5 计算机 王八 1 100
tips:已哪个为基准,就看sql语句,按照提到的表的顺序依次画2个集合,然后再看是内链接还是左/右外链接来取集。