DB2 sql中的内连接和外连接
2012-08-25 09:45
162 查看
有表t1,t2
t1:
C1 C2 C3
-- ---------- --
1 rick B0
2 smith C0
3 john E0
3 条记录已选择。
t2:
C1 C2
-- ----------
A0 sale DEPT
B0 prod DEPT
C0 cout DEPT
D0 mage DEPT
4 条记录已选择。
1.db2的内连接
下面是内连接,内连接和普通的where子句,输出相同,即在两表共有的行才会输出,即也可以用:select * from t1,t2 where t1.c3=t2.c1
内连接没有左右之分.
db2 => select * from t1 inner join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
2 条记录已选择。
2.db2的外连接:外连接分左外连接右外连接,下面我们看看他们的区别:
db2 => select * from t1 left outer join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
3 john E0 - -
3 条记录已选择。
左连接保留前面表的所有记录,后表中没有的补null.
db2 => select * from t1 right outer join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
- - - A0 sale DEPT
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
- - - D0 mage DEPT
4 条记录已选择。
左连接保留后表的所有记录,前表中没有的补null.
我们可以把右连接,的表的顺序颠倒一下,并写成左外连接,其结果应该是一样的.
在DB2的内部机制中,会把右外连接重写成左外连接.故我们在写sql语句时尽量使用左外连接.
3.全外连接.
db2 => select * from t1 full outer join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
- - - A0 sale DEPT
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
- - - D0 mage DEPT
3 john E0 - -
5 条记录已选择。
全外连接会输出两表的所有的数据,包括内连接和左外连接和右外连接的行.
4.与sybase的区别: sybase的sql语句相应的连接有:
select * from t1,t2 where t1.c3=t2.c1 相当于内连接
select * from t1,t2 where t1.c3 *= t2.c1 相当于左外连接
select * from t1,t2 where t1.c3 =* t2.c1 相当于右外连接
总结:
内连接,全有才有;左外连接,左有就有;右外连接,右有就有;全外连接,全都有.
t1:
C1 C2 C3
-- ---------- --
1 rick B0
2 smith C0
3 john E0
3 条记录已选择。
t2:
C1 C2
-- ----------
A0 sale DEPT
B0 prod DEPT
C0 cout DEPT
D0 mage DEPT
4 条记录已选择。
1.db2的内连接
下面是内连接,内连接和普通的where子句,输出相同,即在两表共有的行才会输出,即也可以用:select * from t1,t2 where t1.c3=t2.c1
内连接没有左右之分.
db2 => select * from t1 inner join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
2 条记录已选择。
2.db2的外连接:外连接分左外连接右外连接,下面我们看看他们的区别:
db2 => select * from t1 left outer join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
3 john E0 - -
3 条记录已选择。
左连接保留前面表的所有记录,后表中没有的补null.
db2 => select * from t1 right outer join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
- - - A0 sale DEPT
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
- - - D0 mage DEPT
4 条记录已选择。
左连接保留后表的所有记录,前表中没有的补null.
我们可以把右连接,的表的顺序颠倒一下,并写成左外连接,其结果应该是一样的.
在DB2的内部机制中,会把右外连接重写成左外连接.故我们在写sql语句时尽量使用左外连接.
3.全外连接.
db2 => select * from t1 full outer join t2 on t1.c3=t2.c1
C1 C2 C3 C1 C2
-- ---------- -- -- ----------
- - - A0 sale DEPT
1 rick B0 B0 prod DEPT
2 smith C0 C0 cout DEPT
- - - D0 mage DEPT
3 john E0 - -
5 条记录已选择。
全外连接会输出两表的所有的数据,包括内连接和左外连接和右外连接的行.
4.与sybase的区别: sybase的sql语句相应的连接有:
select * from t1,t2 where t1.c3=t2.c1 相当于内连接
select * from t1,t2 where t1.c3 *= t2.c1 相当于左外连接
select * from t1,t2 where t1.c3 =* t2.c1 相当于右外连接
总结:
内连接,全有才有;左外连接,左有就有;右外连接,右有就有;全外连接,全都有.
相关文章推荐
- .net连接DB2的异常SQL0666 - SQL query exceeds specified time limit or storage limit.错误处理
- C#连接一些常见的数据库(sql,Access,Oracle,Sybase,DB2)
- 使用SqlHelp.cs连接DB2
- ADO.net 中数据库连接方式(sql,access,ora,db2)
- ls jdbc 连接(sql or oracle db2)----终结篇
- ls jdbc 连接(sql or oracle db2)
- 使用Oracle SQLDeveloper 连接DB2
- C_连接Access、SQL_Server、Oracle、MySQL、DB2和SyBase六种不同数据库的程序源码和需要注意的点
- sql 数据库连接 暨 ado.net 小例
- SQL 连接 JOIN 例解。(左连接,右连接,全连接,内连接,交叉连接,自连接)
- SQL左外连接连接多个表
- DB2的JDBC连接驱动和URL总结
- 如何在DB2命令窗口执行sql脚本
- 把两个DataTable连接起来,相当于Sql的Inner Join方法
- DB2 SQL脚本批量执行
- Oracle SQL Developer 连接 MySQL
- sql 2012 与java连接的类
- Win7 x64 PL/SQL 连接 Oralce 提示 Could not initialize "%ORACLE_HOME%\bin\oci.dll"
- SQL多表连接查询(详细实例)
- DB2中,查看某个应用正在执行的SQL语句