久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

怎么在oracle中查詢操作子查詢

154次閱讀
沒有評論

共計 3569 個字符,預計需要花費 9 分鐘才能閱讀完成。

自動寫代碼機器人,免費開通

怎么在 oracle 中查詢操作子查詢?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

一、子查詢語法

SELECT select_list
FROM table
WHERE expr operator (SELECT select_list FROM table);

子查詢在主查詢之前一次執行完成。
子查詢的結果被主查詢使用。

select ename from emp where sal   (select sal from emp where ename= SCOTT

(* 注意:子查詢要包含在括號內,將子查詢放在比較條件的右側。單行操作符對應單行子查詢,多行操作符對應多行子查詢。)

單行子查詢,只返回一行,使用單行比較符(= = = !=)

-- 子查詢中使用組函數
select ename,sal from emp where sal=(select min(sal) from emp);
-- 子查詢中的 having 子句
-- 首先執行子查詢
-- 向主查詢中的 having 子句返回結果
select deptno, min(sal)
 from emp
 group by deptno
having min(sal)   (select min(sal) from emp);

多行子查詢,返回多行,使用多行比較符(IN ANY ALL)

-- 查詢比部門 10 里任意一個人工資高的員工信息
select ename, sal
 from emp
 where sal   any (select sal from emp where deptno = 10);
-- 查詢比部門 20 里所有人工資高的員工信息
select ename, sal
 from emp
 where sal   all (select sal from emp where deptno = 20);
-- 查詢不是老板的員工信息
select ename from emp where empno not in(select mgr from emp);

二、集合運算

并集
UNION 運算符返回兩個集合去掉重復元素后的所有記錄。
UNION ALL 返回兩個集合的所有記錄,包括重復的。
交集
INTERSECT 運算符返回同時屬于兩個集合的記錄

-- 返回工資在 500-1000 和 900-1200 的員工信息
select ename, sal
from emp
where sal between 500 and 1000
intersect
select ename, sal
from emp
where sal between 900 and 1200;

差集

MINUS 返回屬于第一個集合,但不屬于第二個集合的記錄。

-- 返回工資屬于 500-1000,但不屬于 900-1200 的員工信息
select ename, sal
from emp
where sal between 500 and 1000
minus
select ename, sal
from emp
where sal between 900 and 1200;

集合使用的注意事項

1、select 語句中參數類型和個數保持一致。
2、可以使用括號改變集合執行的順序。
3、如果有 order by,必須放到最后一句查詢語句后。
4、集合運算采用第一個語句的表頭作為表頭。

三、數據操作語言

插入數據

INSERT INTO table [(column [,column...])]
VALUES (value [,value...]);
insert into dept(deptno,dname,loc) values(50, test , test

從其他表中拷貝數據

insert into dept(deptno, dname, loc)
select 60, dname, loc from dept where deptno = 10;

更新數據

UPDATE table
SET column=value [, column=value, ...]
[WHERE codition]
-- 更新一條數據
update emp set sal=sal+100 where empno=7369;
--update 使用子查詢
update emp
set sal = (select max(sal) from emp)
where empno = (select empno from emp where sal = (select min(sal) from emp));

刪除數據

DELETE [FROM] table
[WHERE condition];
-- 刪除一條數據
delete from dept where deptno=60;

delete 和 truncate

1、都是刪除表中的數據。
2、delete 操作可以 rollback,可以閃回。
3、delete 可能產生碎片,并且不釋放空間。
4、truncate 清空表。

四、數據庫事務

數據庫事務由以下的部分組成:
1、一個或多個 DML 語句
2、一個 DDL 數據定義語句
3、一個 DCL 數據控制語句

以第一個 DML 語句的執行作為開始
以下面的其中之一作為結束:
顯示結束:commit rollback
隱式結束 (自動提交):DDL 語句,DCL 語句,exit(事務正常退出)
隱式回滾(系統異常終了):關閉窗口,死機,掉電

commit 和 rollback 語句的優點
1、確保數據完整性。
2、數據改變被提交之前預覽。
3、將邏輯上相關的操作分組。

回滾到保留點
使用 savepoint 語句在當前事務中創建保存點。
使用 rollback to savepoint 語句回滾到創建的保存點。

update emp set sal=sal+100 where empno=7369;
savepoint update_empno7369;
delete from emp where empno=7369;
rollback to update_empno7369;

五、創建和管理表

常見的數據庫對象
如下:
表   基本的數據存儲集合,由行和列組成。
視圖   從表中抽出的邏輯上相關的數據集合。
序列   提供有規律的數值。
索引   提高查詢的效率。
同義詞   給對象起別名。

創建表

CREATE TABLE [schema.]table (column datatype [DEFAULT expr][, ...]);
create table test(id number(12),
name varchar2(32));

通過子查詢創建表

CREATE TABLE table [(column, column...)]
AS subquery;
create table test2 as select empno,ename from emp where sal 1000;

修改表

-- 添加列
ALTER TABLE table
ADD (column datatype [DEFAULT expr] [, column datatype] ...);
-- 添加 info 列
alter table test add (info varchar2(256) default  
-- 修改列
ALTER TABLE table
MODIFY (column datatype [DEFAULT expr] [, column datatype] ...);
-- 修改 info 列
alter table test modify (info varchar2(64) default  
-- 刪除列
ALTER TABLE table
DROP column (column);
-- 刪除 info 列
alter table test drop column info;
-- 修改列名
ALTER TABLE table
rename column old_column_name to new_column_name;
-- 修改 name 列名
alter table test rename column name to name2;

刪除表

1、數據和結構都被刪除
2、所有正在運行的相關事物被提交
3、所有相關索引被刪除
4、DROP TABLE 語句不能回滾,但是可以閃回。

drop table test;

改變對象的名稱

rename dept to newDept;

清空表
1、刪除表中所有數據。
2、釋放表的存儲空間。
3、truncate 不能回滾。

truncate table test;

看完上述內容,你們掌握怎么在 oracle 中查詢操作子查詢的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注丸趣 TV 行業資訊頻道,感謝各位的閱讀!

向 AI 問一下細節

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-12-04發表,共計3569字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 油尖旺区| 阳山县| 东城区| 惠东县| 土默特右旗| 洪泽县| 乐山市| 伊金霍洛旗| 清水河县| 林甸县| 体育| 乐陵市| 禄劝| 乐安县| 芮城县| 惠州市| 通道| 伊川县| 托里县| 山阴县| 常宁市| 民乐县| 济宁市| 永寿县| 花莲市| 景谷| 绥滨县| 公主岭市| 青阳县| 许昌市| 兴国县| 弥勒县| 隆安县| 驻马店市| 阳江市| 顺平县| 皮山县| 天门市| 连云港市| 阿合奇县| 名山县|