網站首頁 編程語言 正文
多表查詢基本語法
笛卡爾積在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子句中使用子查詢時,必須給子查詢起別名。(換句話說就是把子查詢查出來的數據作為一張新表,在進行查詢)
總結
原文鏈接:https://blog.csdn.net/weixin_40074861/article/details/123627130
相關推薦
- 2022-03-15 3 Segmentation fault (core dumped) ./a.out Exited
- 2022-08-23 Pandas?Matplotlib保存圖形時坐標軸標簽太長導致顯示不全問題的解決_python
- 2023-12-07 com.fasterxml.jackson.databind.ObjectMapper
- 2022-10-15 使用Pycharm創建一個Django項目的超詳細圖文教程_python
- 2022-11-01 Android事件分發機制?ViewGroup分析_Android
- 2022-12-26 Python標準庫os常用函數和屬性詳解_python
- 2023-04-18 C語言計算連續無序數組中缺省數字方法詳解_C 語言
- 2022-01-16 ES6箭頭函數、rest參數、擴展運算符、Symbol的使用
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支