麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > Oracle > 正文

oracle基本查詢操作子查詢用法實例分析

2020-07-26 13:25:56
字體:
來源:轉載
供稿:網友

本文實例講述了oracle基本查詢操作子查詢用法。分享給大家供大家參考,具體如下:

一、子查詢語法

SELECT select_listFROM tableWHERE 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 deptnohaving 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, salfrom empwhere sal between 500 and 1000intersectselect ename, salfrom empwhere sal between 900 and 1200;

差集

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

--返回工資屬于500-1000,但不屬于900-1200的員工信息select ename, salfrom empwhere sal between 500 and 1000minusselect ename, salfrom empwhere 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 tableSET column=value [, column=value, ...][WHERE codition]
--更新一條數據update emp set sal=sal+100 where empno=7369;
--update使用子查詢update empset 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 tableADD (column datatype [DEFAULT expr] [, column datatype] ...);--添加info列alter table test add (info varchar2(256) default '');--修改列ALTER TABLE tableMODIFY (column datatype [DEFAULT expr] [, column datatype] ...);--修改info列alter table test modify (info varchar2(64) default '');--刪除列ALTER TABLE tableDROP column (column);--刪除info列alter table test drop column info;--修改列名ALTER TABLE tablerename 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相關內容感興趣的讀者可查看本站專題:《Oracle常用函數匯總》、《Oracle日期與時間操作技巧總結》及《php+Oracle數據庫程序設計技巧總結》

希望本文所述對大家Oracle數據庫程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品91久久久 | 国产二区三区在线播放 | 亚洲成人入口 | 一区二区三区在线观看国产 | 福利免费在线观看 | 久久99精品久久久久久236 | 久精品久久 | 毛片在线播放视频 | 免费a视频在线观看 | 毛片网站视频 | 斗罗破苍穹在线观看免费完整观看 | 国产亚洲精品久久久久久久久久 | 国产精品呻吟 | 成人午夜久久 | 成人福利视频导航 | 国产一区二区三区色淫影院 | 亚洲成人涩涩 | 深夜毛片免费看 | 欧美aⅴ视频 | 成年人在线免费播放视频 | 国产亚洲精品美女久久久 | 久久免费综合视频 | 久综合| 欧美一级黄色影院 | 久久国产91| 午夜视频啊啊啊 | 女女久久| 免费观看黄视频 | 欧美1区2区在线观看 | 91九色视频在线播放 | 欧美一级在线免费 | 97超碰资源站 | 成人免费视频 | 精品国产一区二区三区久久久蜜 | 久久免费看片 | 精品一区二区三区在线视频 | 97中文字幕在线观看 | 中国黄色一级生活片 | 视频一区国产 | 成人免费一区二区三区 | 国产91在线亚洲 |