表的连接(一)
来源:互联网 发布:魔方软件官方下载 编辑:程序博客网 时间:2024/06/01 09:42
表的连接:
1、等值连接(简单连接或内部连接):是在WHERE子句中使用等号。等值连接通常被称为简单连接或内部连接。
select a.x,b.x from tableA a,tableB b where a.id=b.id;
通常,根据给定的条件返回行数最少的表会作为驱动表--也就是基表。
不等值联合:是在WHERE子句中使用除了等号以外的其它比较运算符。
2、外部连接
外部连接的运算符是用括号括起来的加号(+)。语法:
select t1.column,t2.column from table t1,table2 t2
where t1.column(+)=t2.column;
或
select t1.column,t2.column from table t1,table2 t2
where t1.column=t2.column(+);
外部连接注意事项:
(1)外部连接运算符只能放在连接条件表达式的一侧,即缺少相关连接信息的表一侧。它能返回该表中那些在另一个表中没有得到匹配的记录。
3、自身连接
--自身连接,查询每位雇员的上级主管
select e.ename||' works for '||m.ename
from emp e,emp m
where e.mgr=m.empno
4、SQL:1999语法的连接
在查询中使用SQL:1999语法可以达到和前面所介绍的方法同样的效果。
(1)交叉连接:
CROSS JOIN 子句会产生两个表的交叉乘积,和两个表之间的笛卡尔积是一样的。
(2)自然连接
NATURAL JOIN 使用所有名称和数据类型相匹配的列连接两个表
使用NATURAL JOIN关键字可以实现具有列名和数据类型相匹配的两个表之间的自动连接。
使用自然连接时应注意以下事项:
a、自然连接子句是基于两个表存在相同名字的列。
b、返回两个表相匹配列中具有相同值的记录。
c、如果相同名称的列的数据类型不同,则会产生错误。
例子:
--自然连接,EMP表和DEPT表的自然连接
select empno,ename,sal,deptno,loc
from emp
natural join dept
where deptno in(20,30);
1、等值连接(简单连接或内部连接):是在WHERE子句中使用等号。等值连接通常被称为简单连接或内部连接。
select a.x,b.x from tableA a,tableB b where a.id=b.id;
通常,根据给定的条件返回行数最少的表会作为驱动表--也就是基表。
不等值联合:是在WHERE子句中使用除了等号以外的其它比较运算符。
2、外部连接
外部连接的运算符是用括号括起来的加号(+)。语法:
select t1.column,t2.column from table t1,table2 t2
where t1.column(+)=t2.column;
或
select t1.column,t2.column from table t1,table2 t2
where t1.column=t2.column(+);
外部连接注意事项:
(1)外部连接运算符只能放在连接条件表达式的一侧,即缺少相关连接信息的表一侧。它能返回该表中那些在另一个表中没有得到匹配的记录。
3、自身连接
--自身连接,查询每位雇员的上级主管
select e.ename||' works for '||m.ename
from emp e,emp m
where e.mgr=m.empno
4、SQL:1999语法的连接
在查询中使用SQL:1999语法可以达到和前面所介绍的方法同样的效果。
(1)交叉连接:
CROSS JOIN 子句会产生两个表的交叉乘积,和两个表之间的笛卡尔积是一样的。
(2)自然连接
NATURAL JOIN 使用所有名称和数据类型相匹配的列连接两个表
使用NATURAL JOIN关键字可以实现具有列名和数据类型相匹配的两个表之间的自动连接。
使用自然连接时应注意以下事项:
a、自然连接子句是基于两个表存在相同名字的列。
b、返回两个表相匹配列中具有相同值的记录。
c、如果相同名称的列的数据类型不同,则会产生错误。
例子:
--自然连接,EMP表和DEPT表的自然连接
select empno,ename,sal,deptno,loc
from emp
natural join dept
where deptno in(20,30);
- 表的连接(一)
- oracle表连接(一)
- PostgreSQL的查询语句的连接方式与查询计划比较--多表连接(一)
- 表的自连接一例
- Oracel中连接的总结(一)
- SQL SERVER的连接方式(一)
- 字符串连接超长的解决(一)
- TCP连接的建立(一)
- 连接池的使用(一)
- Grip的使用(一)连接数据库
- php的PDO连接数据库(一)
- 数据库的连接 (一)
- 数据库查询中的表连接(一)
- 多表连接一
- MySQL漂流记之常用(一)--左连接+右连接+内连接的本质区别
- 网络连接(一)
- 连接池(一)
- Spring(一) 关于连接池的方式的总结
- Android frambuffer 驱动的简要解析
- SQL子句
- 模拟键盘、鼠标 mouse_event keybd_event
- struts防止重复提交
- java 读取工程下面的配置文件
- 表的连接(一)
- 实时传输协议RTP
- 表的连接(二)
- Web Site 与 Web Application 的区别
- Bean的作用域
- pc使用利器,适合长期使用pc的人们
- 表的连接(三)
- 二维码(QR)
- C++ explicit关键字应用方法详解(转转转)