oracle多表簡單查詢實例代碼
多表查詢基本語法
笛卡爾積在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多表查詢內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
教你使用PLSQLDeveloper14連接Oracle11g的詳細過程
今天給大家帶來一篇教程關于用PLSQLDeveloper14連接Oracle11g的詳細過程,本文分步驟通過圖文并茂的形式給大家介紹的非常詳細,需要的朋友參考下吧2021-09-09oracle ORA-01114、ORA-27067錯誤解決方法
本文章總結了關于ORA-01114、ORA-27067錯誤解決方法,有需要學習的朋友可參考一下下哦2012-10-10
最新評論