oracle多表簡(jiǎn)單查詢(xún)實(shí)例代碼
多表查詢(xún)基本語(yǔ)法
笛卡爾積在SQL中的實(shí)現(xiàn)方式既是交叉連接(Cross Join)。所有連接方式都會(huì)先生成臨時(shí)笛卡爾積表,笛卡爾積是關(guān)系代數(shù)里的一個(gè)概念,表示兩個(gè)表中的每一行數(shù)據(jù)任意組合。
-- 笛卡爾積 select * from emp, dept;
oracle多表查詢(xún)


prompt Importing table dept... set feedback off set define off insert into dept (DEPTNO, DNAME, LOC) values (1, '01事業(yè)部', '324'); insert into dept (DEPTNO, DNAME, LOC) values (2, '02事業(yè)部', '234'); insert into dept (DEPTNO, DNAME, LOC) values (3, '03事業(yè)部', '234'); insert into dept (DEPTNO, DNAME, LOC) values (4, '04事業(yè)部', '3244'); prompt Done.
prompt Importing table emp...
set feedback off
set define off
insert into emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values ('001', '小明', '運(yùn)維', '9000', to_date('26-09-2021', 'dd-mm-yyyy'), 900, 800, '1');
insert into emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values ('001', '小剛', 'hr', '7000', to_date('26-09-2021', 'dd-mm-yyyy'), 900, 800, '1');
insert into emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values ('001', '小花', 'vue開(kāi)發(fā)', '6000', to_date('26-09-2021', 'dd-mm-yyyy'), 900, 800, '1');
insert into emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values ('001', '小貝', '軟件工程師', '9000', to_date('26-09-2021', 'dd-mm-yyyy'), 900, 800, '2');
insert into emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values ('001', '小濤', '數(shù)據(jù)中臺(tái)', '11000', to_date('26-09-2021', 'dd-mm-yyyy'), 900, 800, '2');
insert into emp (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)
values ('001', '小勝', '設(shè)計(jì)', '9000', to_date('26-09-2021', 'dd-mm-yyyy'), 900, 800, '2');
prompt Done.prompt
prompt Creating table DEPT
prompt ===================
prompt
create table USERNAME.DEPT
(
deptno NUMBER not null,
dname VARCHAR2(10) not null,
loc VARCHAR2(10) not null
)
tablespace USERS
pctfree 10
initrans 1
maxtrans 255
storage
(
initial 64K
next 1M
minextents 1
maxextents unlimited
);
prompt
prompt Creating table EMP
prompt ==================
prompt
create table USERNAME.EMP
(
empno NVARCHAR2(20),
ename NVARCHAR2(20),
job NVARCHAR2(20),
mgr NVARCHAR2(20),
hiredate DATE,
sal BINARY_DOUBLE,
comm BINARY_DOUBLE,
deptno NVARCHAR2(20)
)
tablespace USERS
pctfree 10
initrans 1
maxtrans 255
storage
(
initial 64K
next 1M
minextents 1
maxextents unlimited
);
prompt Done
spool off
set define on多表查詢(xún)
多表查詢(xún):多表查詢(xún)是指基于兩個(gè)或兩個(gè)以上的表或者視圖的查詢(xún)。
--查詢(xún)員工名,工資,以及員工所在部門(mén)的名稱(chēng)
select e.ename,e.sal,d.dname from emp e,dept d where e.deptno=d.deptno
--查詢(xún)部門(mén)編號(hào)為10的部門(mén)名稱(chēng),員工名稱(chēng),工資
select d.dname,e.ename,e.sal from emp e,dept d where e.deptno=d.deptno and d.deptno='1'
--查詢(xún)員工名稱(chēng),工資,部門(mén)名稱(chēng),并且按照部門(mén)名稱(chēng)升序排列
select e.ename,e.sal,d.dname from emp e,dept d where e.deptno=d.deptno order by d.dname
--2.自連接
-- 自連接:自連接是指在同一張表上的連接查詢(xún)
--查詢(xún)員工的姓名以及員工所對(duì)應(yīng)老板的姓名
select e1.ename,e2.ename from emp e1,emp e2 where e1.mgr=e2.empno
3.子查詢(xún)(單行子查詢(xún))
子查詢(xún):子查詢(xún)是指嵌入在其他sql語(yǔ)句中的select語(yǔ)句,也叫嵌套查詢(xún)。
--查詢(xún)與SMITH在同一部門(mén)的員工 select * from (select e.deptno from emp e,dept t where e.deptno=t.deptno and e.ename='SMITH') s1,emp e where e.deptno =s1.deptno select * from emp where deptno=(select deptno from emp where ename='SMITH');
多行子查詢(xún)
多行子查詢(xún)是指返回多行數(shù)據(jù)的查詢(xún)。
在多行子查詢(xún)中使用all操作符
--查詢(xún)與10號(hào)部門(mén)工作相同的員工名稱(chēng),工作,工資,部門(mén)編號(hào) select ename,job,sal,deptno from emp where job in (select job from emp where deptno=1); --查詢(xún)比30號(hào)部門(mén)所有人工資高的員工姓名,職位,工資,部門(mén)編號(hào) select ename,sal,job,deptno from emp where sal>all(select sal from emp where deptno=1); --在多行子查詢(xún)中使用any操作符 --查詢(xún)比1號(hào)部門(mén)任意人工資高的員工姓名,職位,工資,部門(mén)編號(hào) select ename,sal,job,deptno from emp where sal>any(select sal from emp where deptno=1);
多列子查詢(xún)
單行子查詢(xún)是指子查詢(xún)返回單行,單列的數(shù)據(jù)
多行子查詢(xún)是指子查詢(xún)返回多行,單列的數(shù)據(jù)
多列子查詢(xún)是指子查詢(xún)返回多列數(shù)據(jù)的查詢(xún)
--查詢(xún)與SMITH的部門(mén)和職位完全相同的員工信息 select * from emp where (deptno,job)=(select deptno,job from emp where ename='SMITH');
在from子句中使用子查詢(xún)
在from子句中使用子查詢(xún)時(shí),該子查詢(xún)會(huì)被當(dāng)做一個(gè)視圖來(lái)對(duì)待,因此也就叫做內(nèi)嵌圖,當(dāng)在from子句中使用子查詢(xún)時(shí),必須給子查詢(xún)起別名。(換句話(huà)說(shuō)就是把子查詢(xún)查出來(lái)的數(shù)據(jù)作為一張新表,在進(jìn)行查詢(xún))
總結(jié)
到此這篇關(guān)于oracle多表簡(jiǎn)單查詢(xún)的文章就介紹到這了,更多相關(guān)oracle多表查詢(xún)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
oracle多表簡(jiǎn)單查詢(xún)實(shí)例代碼
當(dāng)查詢(xún)的數(shù)據(jù)并不是來(lái)源一個(gè)表時(shí),需要使用多表鏈接操作完成查詢(xún),下面這篇文章主要給大家介紹了關(guān)于oracle多表簡(jiǎn)單查詢(xún)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04
oracle查詢(xún)語(yǔ)句大全(oracle 基本命令大全一)
這篇文章主要介紹了oracle查詢(xún)語(yǔ)句,有助于新手迅速熟悉ORACLE基本語(yǔ)法有助于新手迅速熟悉ORACLE基本語(yǔ)法,需要的朋友可以收藏下2013-08-08
使用sqlplus命令行工具為oracle創(chuàng)建用戶(hù)和表空間
這篇文章主要介紹了使用sqlplus為oracle創(chuàng)建用戶(hù)和表空間的方法,本文介紹的是使用Oracle 9i所帶的命令行工具:SQLPLUS,需要的朋友可以參考下2017-11-11
Mybatis出現(xiàn)ORA-00911: invalid character的解決辦法
今天在項(xiàng)目中,使用Mybatis對(duì)oracle數(shù)據(jù)庫(kù)進(jìn)行操作的時(shí)候,報(bào)出ORA-00911: invalid character的錯(cuò)誤,檢查了一下SQL,發(fā)現(xiàn)都書(shū)寫(xiě)正確啊,復(fù)制到plsql上執(zhí)行也都沒(méi)問(wèn)題,這什么原因呢,下面通過(guò)本文給大家解答下2016-12-12
windows下oracle 11g r2 安裝過(guò)程與卸載詳細(xì)圖解
這篇文章主要介紹了windows下oracle 11g r2 安裝過(guò)程與卸載詳細(xì)圖解,需要的朋友可以參考下2016-04-04

