1. 程式人生 > 資料庫 >oracle基本查詢操作子查詢用法例項分析

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

本文例項講述了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,loc)
select 60,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相關內容感興趣的讀者可檢視本站專題:《Oracle常用函式彙總》、《Oracle日期與時間操作技巧總結》及《php+Oracle資料庫程式設計技巧總結》

希望本文所述對大家Oracle資料庫程式設計有所幫助。