a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁(yè) > 數(shù)據(jù)庫(kù) > Oracle > 正文

oracle基本查詢操作子查詢用法實(shí)例分析

2020-07-26 13:25:56
字體:
供稿:網(wǎng)友

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

一、子查詢語(yǔ)法

SELECT select_listFROM tableWHERE expr operator (SELECT select_list FROM table);

子查詢?cè)谥鞑樵冎耙淮螆?zhí)行完成。
子查詢的結(jié)果被主查詢使用。

select ename from emp where sal > (select sal from emp where ename='SCOTT');

(*注意:子查詢要包含在括號(hào)內(nèi),將子查詢放在比較條件的右側(cè)。單行操作符對(duì)應(yīng)單行子查詢,多行操作符對(duì)應(yīng)多行子查詢。)

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

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

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

--查詢比部門10里任意一個(gè)人工資高的員工信息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);

二、集合運(yùn)算

并集
UNION運(yùn)算符返回兩個(gè)集合去掉重復(fù)元素后的所有記錄。
UNION ALL 返回兩個(gè)集合的所有記錄,包括重復(fù)的。
交集
INTERSECT 運(yùn)算符返回同時(shí)屬于兩個(gè)集合的記錄

--返回工資在500-1000和900-1200的員工信息select ename, salfrom empwhere sal between 500 and 1000intersectselect ename, salfrom empwhere sal between 900 and 1200;

差集

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

--返回工資屬于500-1000,但不屬于900-1200的員工信息select ename, salfrom empwhere sal between 500 and 1000minusselect ename, salfrom empwhere sal between 900 and 1200;

集合使用的注意事項(xiàng)

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

三、數(shù)據(jù)操作語(yǔ)言

插入數(shù)據(jù)

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

從其他表中拷貝數(shù)據(jù)

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

更新數(shù)據(jù)

UPDATE tableSET column=value [, column=value, ...][WHERE codition]
--更新一條數(shù)據(jù)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));

刪除數(shù)據(jù)

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

delete和truncate

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

四、數(shù)據(jù)庫(kù)事務(wù)

數(shù)據(jù)庫(kù)事務(wù)由以下的部分組成:
1、一個(gè)或多個(gè)DML語(yǔ)句
2、一個(gè)DDL數(shù)據(jù)定義語(yǔ)句
3、一個(gè)DCL數(shù)據(jù)控制語(yǔ)句

以第一個(gè)DML語(yǔ)句的執(zhí)行作為開始
以下面的其中之一作為結(jié)束:
顯示結(jié)束:commit rollback
隱式結(jié)束(自動(dòng)提交):DDL語(yǔ)句,DCL語(yǔ)句,exit(事務(wù)正常退出)
隱式回滾(系統(tǒng)異常終了):關(guān)閉窗口,死機(jī),掉電

commit和rollback語(yǔ)句的優(yōu)點(diǎn)
1、確保數(shù)據(jù)完整性。
2、數(shù)據(jù)改變被提交之前預(yù)覽。
3、將邏輯上相關(guān)的操作分組。

回滾到保留點(diǎn)
使用savepoint語(yǔ)句在當(dāng)前事務(wù)中創(chuàng)建保存點(diǎn)。
使用rollback to savepoint語(yǔ)句回滾到創(chuàng)建的保存點(diǎn)。

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

五、創(chuàng)建和管理表

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

創(chuàng)建表

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

通過子查詢創(chuàng)建表

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、數(shù)據(jù)和結(jié)構(gòu)都被刪除
2、所有正在運(yùn)行的相關(guān)事物被提交
3、所有相關(guān)索引被刪除
4、DROP TABLE語(yǔ)句不能回滾,但是可以閃回。

drop table test;

改變對(duì)象的名稱

rename dept to newDept;

清空表
1、刪除表中所有數(shù)據(jù)。
2、釋放表的存儲(chǔ)空間。
3、truncate不能回滾。

truncate table test;

更多關(guān)于Oracle相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Oracle常用函數(shù)匯總》、《Oracle日期與時(shí)間操作技巧總結(jié)》及《php+Oracle數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》

希望本文所述對(duì)大家Oracle數(shù)據(jù)庫(kù)程序設(shè)計(jì)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 日韩精品免费在线观看 | 久久精品久 | 欧美激情性国产欧美无遮挡 | 午夜精品久久久久久久久久久久久蜜桃 | 欧美日韩一区二区视频在线观看 | 成人国产在线观看 | 日韩在线视频网站 | 黄色在线免费观看视频 | 久久91久久久久麻豆精品 | 夜久久| 免费成人在线网站 | 曰逼视频 | 亚洲激情在线播放 | 久久国产精品99久久久久久老狼 | 国产精品视频一区二区噜噜 | 国产三区二区一区 | 在线观看国产小视频 | 国产精品久久久久久久久 | 国产欧美一区二区 | 青青草免费在线视频 | 成人在线www | 色玖玖综合 | 秋霞影院午夜丰满少妇在线视频 | 国产一级片一区二区三区 | 午夜视频色 | 91精选国产 | 国产精品久久嫩一区二区 免费 | 欧洲美女7788成人免费视频 | 正在播放欧美 | 日韩欧美国产一区二区 | 久久精美视频 | 精品国产露脸精彩对白 | 亚洲视频三区 | 男女视频免费在线观看 | 日韩免费福利视频 | 久久国产精品一区二区三区 | 三级特黄特色视频 | 综合网视频 | 99国产精品99久久久久久 | 69黄在线看片免费视频 | 男女羞羞视频在线观看 |