大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
select e.empno, e.ename, d.deptno, d.dname
创新互联-专业网站定制、快速模板网站建设、高性价比凤山网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式凤山网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖凤山地区。费用合理售后完善,十多年实体公司更值得信赖。
from emp e, dept d
where e.deptno = d.deptno;
在之前所使用的查询操作之中,都是从一张表之中查询出所需要的内容,那么如果现在一个查询语句需要显示多张表的数据,则就必须应用到多表查询的操作,而多表查询的语法如下:
SELECT [DISTINCT] * | 字段 [别名] [,字段 [别名] ,…] FROM 表名称 [别名], [表名称 [别名] ,…] [WHERE 条件(S)] [ORDER BY 排序字段 [ASC|DESC] [,排序字段 [ASC|DESC] ,…]]。
扩展资料:
Oracle 常用的关联查询:
Oracle外连接:
(1)左外连接 (左边的表不加限制)。
(2)右外连接(右边的表不加限制)。
(3)全外连接(左右两表都不加限制)。
outer join则会返回每个满足第一个(顶端)输入与第二个(底端)输入的联接的行。它还返回任何在第二个输入中没有匹配行的第一个输入中的行。
外连接分为三种: 左外连接,右外连接,全外连接。 对应SQL:LEFT/RIGHT/FULL OUTER JOIN。 通常我们省略outer 这个关键字。 写成:LEFT/RIGHT/FULL JOIN。
在左外连接和右外连接时都会以一张表为基表,该表的内容会全部显示,然后加上两张表匹配的内容。 如果基表的数据在另一张表没有记录。 那么在相关联的结果集行中列显示为空值(NULL)。
用CTE加UNION 试试吧
WITH A AS
(SELECT BASE_TINYAREA.TINY_NAME, COUNT(CONTR_NAME) 授权网店
FROM BASE_TINYAREA, NETP_ORDERNET
WHERE NETP_ORDERNET.TINY_ID IN (SELECT ID FROM BASE_TINYAREA)
AND BASE_TINYAREA.ID = NETP_ORDERNET.TINY_ID(+)
GROUP BY BASE_TINYAREA.TINY_NAME),
B AS
(SELECT BASE_TINYAREA.TINY_NAME, COUNT(C1.SHOP_TYPE) 直供网店
FROM BASE_TINYAREA, NETP_SUPPNET C1
WHERE C1.TINY_ID IN (SELECT ID FROM BASE_TINYAREA)
AND BASE_TINYAREA.ID = C1.TINY_ID(+)
AND C1.SHOP_TYPE = 7
GROUP BY BASE_TINYAREA.TINY_NAME)
SELECT NVL(A.TINY_NAME, B.TINY_NAME), 授权网店, 直供网店
FROM A
FULL JOIN B
ON A.TINY_NAME = B.TINY_NAME
oracle中多表连接有很多种方式:
1、表与表连接有三种方式Nested loop, Hash join, Sort merge join。
2、Nested Loop就是循环嵌套的连接方法,对于被连接子集都是比较小的话,嵌套循环就是比较好的选择。在嵌套中,内表被外表驱动,外表做一次循环,内表针对外表的每一行做循环。
3、这种表的返回结果集不能太大,否则就效率实在太低的,而且还要用在表都有索引的情况下才行的。
4、Sort Merge Join 用在数据没有索引,并且数据必须是都排序号的情况。
5、总之,两表之间相连,会根据表之间的不同情况选择不同的连接方式,连接其实就是做表之间每行数据的遍历,连之前都要做好准备,有么用索引,要么用已排序号的表,要么就用hash算法,不存在什么都不准备的纯遍历循环。
6、三种连接使用前提,当表都排序号的话用Sort Merge Join连接,当两表都差不多大而且都还有索引就用Nested Loop的嵌套连接,当没有索引也没排序,而且数据量大的情况下就用这个hash算法进行相连。