6、以我们在写内连接的时候可以省略inner这个关键字。1.2下面举例来说明内连接:1.2.1先创建2张测试表并插入数据:1.SQL> select * from dave; 2.ID NAME 3.---------- ---------- 4.1 dave 5.2 bl 6.1 bl 7.2 dave 8. 9. 10.SQL> select * from bl; 11.ID NAME 12.---------- ---------- 13.1 dave 14.2 bl 1.2.3用内链
7、接进行查询:1.SQL> Select a.id,a.name,b.name from dave a inner join bl b on a.id=b.id; -- 标准写法 2.ID NAME NAME 3.---------- ---------- ---------- 4.1 dave dave 5.2 bl bl 6.1 bl dave 7.2 dave bl 8. 9. 10.SQL> Select a.id,a.nam
8、e,b.name from dave a join bl b on a.id=b.id; -- 这里省略了inner 关键字 11.ID NAME NAME 12.---------- ---------- ---------- 13.1 dave dave 14.2 bl bl 15.1 bl dave 16.2 dave bl 17. 18. 19.SQL> Select a.id,a.name,b.name from dave
9、a,bl b where a.id=b.id; -- select 多表查询 20.ID NAME NAME 1.---------- ---------- ---------- 2.1 dave dave 3.2 bl bl 4.1 bl dave 5.2 dave bl 从这三个SQL的结果我们也可以看出,他们的作用是一样的。1.3自然连接(Naturaljoin)自然连接是在两张表中寻找那些数据类型和列名都相同的字段,然后自动地
10、将他们连接起来,并返回所有符合条件按的结果。先看一下自然连接的例子:1.SQL> Select id,name from dave a natural join bl b; 2.ID NAME 3.---------- ---------- 4.1 dave 5.2 bl 这里我们并没有指定连接的条件,实际上oracle为我们自作主张的将,dave表中的id和name字段与bl表中的id和name字段进行了连接。也就是实际上相当于1.SQL> Select dave.id,bl.name 2.From
11、dave join bl on dave.id = bl.id and dave.name=bl.name; 3.ID NAME 4.---------- ---------- 5.1 dave 6.2 bl 因此,我们也可以将自然连接理解为内连接的一种。有关自然连接的一些注意事项:(1).如果做自然连接的两个表的有多个字段都满足有相同名称和类型,那么他们会被作为自然连接的条件。(2).如果自然连接的两个表仅是字段名称相同,但数据类型不同,