oracle连表语法
1.笛卡尔积 (表一乘以表二) (表连接建立在笛卡尔积上过滤)
select * from emp,dept;
2.等值连接 (表与表之见有相同的列表)
select ename,dname from emp,dept where emp.deptno=dept.depton;
3.不等值连接(用不同的列表判断连接)
select * from emp,salgrade where sal between losal and hisal;
4.自连(表一与表一连接)
select * from emp,emp ;
5.外连接( 在等值基础上,确保一张表(主表)的记录都存在 从表满足则匹配,不满足补充null)
1.左外:(+)放等号左边表示左外连接
select * from emp e,dept d where d.deptno = e.deptno(+);
2.右外:(+)放等号左边表示右外连接
select * from emp e,dept d where d.deptno(+) = e.deptno;
1999版
1.cross join 交叉连接(交叉连接就是笛卡尔积)
select * from emp cross join dept;
2.natural join (自然连接 两表有相等列表自动连接)
3.[inner] join 内连接 == 等值连接 如果不加inner关键字,那么默认就是内连接 ,内连接必须有on关键字
on关键字表示连接条件(可省略inner关键字)
4.left/right [outer] join 左/右外连接 外链接也需要on关键字 left左边的表多数据 right右边的表多数据 补空
5.full [outer] join 全外连接 左右两张表都分开补nul;l
浙公网安备 33010602011771号