首頁 > 軟體

oracle多表簡單查詢範例程式碼

2022-04-15 16:00:28

多表查詢基本語法

笛卡爾積在SQL中的實現方式既是交叉連線(Cross Join)。所有連線方式都會先生成臨時笛卡爾積表,笛卡爾積是關係代數裡的一個概念,表示兩個表中的每一行資料任意組合。

-- 笛卡爾積 
select * from emp, dept;

oracle多表查詢

prompt Importing table dept...
set feedback off
set define off
insert into dept (DEPTNO, DNAME, LOC)
values (1, '01事業部', '324');
 
insert into dept (DEPTNO, DNAME, LOC)
values (2, '02事業部', '234');
 
insert into dept (DEPTNO, DNAME, LOC)
values (3, '03事業部', '234');
 
insert into dept (DEPTNO, DNAME, LOC)
values (4, '04事業部', '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', '小明', '運維', '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開發', '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', '小濤', '資料中臺', '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', '小勝', '設計', '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

多表查詢

多表查詢:多表查詢是指基於兩個或兩個以上的表或者檢視的查詢。

--查詢員工名,工資,以及員工所在部門的名稱
select   e.ename,e.sal,d.dname   from   emp e,dept d  where e.deptno=d.deptno                    
--查詢部門編號為10的部門名稱,員工名稱,工資
select  d.dname,e.ename,e.sal  from   emp e,dept d  where e.deptno=d.deptno   and d.deptno='1' 
--查詢員工名稱,工資,部門名稱,並且按照部門名稱升序排列
select   e.ename,e.sal,d.dname  from   emp e,dept d  where e.deptno=d.deptno   order by d.dname 

--2.自連線

-- 自連線:自連線是指在同一張表上的連線查詢

--查詢員工的姓名以及員工所對應老闆的姓名

select   e1.ename,e2.ename  from    emp  e1,emp e2 where e1.mgr=e2.empno

3.子查詢(單行子查詢)

子查詢:子查詢是指嵌入在其他sql語句中的select語句,也叫巢狀查詢。

--查詢與SMITH在同一部門的員工
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');

多行子查詢

多行子查詢是指返回多行資料的查詢。

在多行子查詢中使用all操作符

 
 
--查詢與10號部門工作相同的員工名稱,工作,工資,部門編號
select ename,job,sal,deptno from emp where job in (select job from emp where deptno=1);
 
--查詢比30號部門所有人工資高的員工姓名,職位,工資,部門編號
select ename,sal,job,deptno from emp where sal>all(select sal from emp where deptno=1);
 
--在多行子查詢中使用any操作符
--查詢比1號部門任意人工資高的員工姓名,職位,工資,部門編號
select ename,sal,job,deptno from emp where sal>any(select sal from emp where deptno=1);

多列子查詢

單行子查詢是指子查詢返回單行,單列的資料

多行子查詢是指子查詢返回多行,單列的資料

多列子查詢是指子查詢返回多列資料的查詢

--查詢與SMITH的部門和職位完全相同的員工資訊
 
select * from emp where (deptno,job)=(select deptno,job from emp where ename='SMITH');

在from子句中使用子查詢

在from子句中使用子查詢時,該子查詢會被當做一個檢視來對待,因此也就叫做內嵌圖,當在from子句中使用子查詢時,必須給子查詢起別名。(換句話說就是把子查詢查出來的資料作為一張新表,在進行查詢)

總結

到此這篇關於oracle多表簡單查詢的文章就介紹到這了,更多相關oracle多表查詢內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com