数据表的连接有: 1.内连接(自然连接): 只有两个表相匹配的行才能在结果集中出现 2.外连接: 包括 (1)左外连接(左边的表不加限制) (2)右外连接(右边的表不加限制) (3)全外连接(左右两表都不加限制) 3.自连接(连接发生在一张基表内) select a.studentno, a.studentname, b.classname from students a, classes b where a.classid(+) = b.classid; STUDENTNO STUDENTNA
先创建2个表:学生表和教师表 1.内连接: 在每个表中找出符合条件的共有记录.[x inner join y on...] 第一种写法:只用where SELECT t.TEACHER_NAME,s.STUDENT_NAME FROM teacher t,student s WHERE t.ID=s.TEACHER_ID 第二种写法:使用 join..on.. SELECT t.TEACHER_NAME,s.STUDENT_NAME FROM teacher t JOIN student s
数据准备: create table T1( A ) not null, B ) not null, C tinyint not null ); create table T2( B ) not null, E tinyint not null ); insert into T1 values (), (), (), (); insert into T2 values (), (), (), (), (); select * from T1; select * from T2; 结果: A B
1.内连接.两个表的公共部分用Inner join,Inner join是交集的部分. Select * from TableA A inner join TableB B on A.key=B.key 2.左外连接.A表和B表的共有,加上A的独有,简称全A. Select * from TableA A left join TableB B on A.key=B.key 红色部分是两表的公有部分,此时8号记录是A表的独有,右边的部门表并没有满足的就用null补齐. 3.右外连接.A表和B表的共