怎么在oracle中查询操作子查询?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

一、子查询语法

SELECTselect_listFROMtableWHEREexproperator(SELECTselect_listFROMtable);

子查询在主查询之前一次执行完成。
子查询的结果被主查询使用。

selectenamefromempwheresal>(selectsalfromempwhereename='SCOTT');

(*注意:子查询要包含在括号内,将子查询放在比较条件的右侧。单行操作符对应单行子查询,多行操作符对应多行子查询。)

单行子查询,只返回一行,使用单行比较符(> = < >= <= != <>)

--子查询中使用组函数selectename,salfromempwheresal=(selectmin(sal)fromemp);--子查询中的having子句--首先执行子查询--向主查询中的having子句返回结果selectdeptno,min(sal)fromempgroupbydeptnohavingmin(sal)>(selectmin(sal)fromemp);

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

--查询比部门10里任意一个人工资高的员工信息selectename,salfromempwheresal>any(selectsalfromempwheredeptno=10);--查询比部门20里所有人工资高的员工信息selectename,salfromempwheresal>all(selectsalfromempwheredeptno=20);--查询不是老板的员工信息selectenamefromempwhereempnonotin(selectmgrfromemp);

二、集合运算

并集
UNION运算符返回两个集合去掉重复元素后的所有记录。
UNION ALL 返回两个集合的所有记录,包括重复的。
交集
INTERSECT 运算符返回同时属于两个集合的记录

--返回工资在500-1000和900-1200的员工信息selectename,salfromempwheresalbetween500and1000intersectselectename,salfromempwheresalbetween900and1200;

差集

MINUS 返回属于第一个集合,但不属于第二个集合的记录。

--返回工资属于500-1000,但不属于900-1200的员工信息selectename,salfromempwheresalbetween500and1000minusselectename,salfromempwheresalbetween900and1200;

集合使用的注意事项

1、select语句中参数类型和个数保持一致。
2、可以使用括号改变集合执行的顺序。
3、如果有order by,必须放到最后一句查询语句后。
4、集合运算采用第一个语句的表头作为表头。

三、数据操作语言

插入数据

INSERTINTOtable[(column[,column...])]VALUES(value[,value...]);

insertintodept(deptno,dname,loc)values(50,'test','test');

从其他表中拷贝数据

insertintodept(deptno,dname,loc)select60,dname,locfromdeptwheredeptno=10;

更新数据

UPDATEtableSETcolumn=value[,column=value,...][WHEREcodition]

--更新一条数据updateempsetsal=sal+100whereempno=7369;

--update使用子查询updateempsetsal=(selectmax(sal)fromemp)whereempno=(selectempnofromempwheresal=(selectmin(sal)fromemp));

删除数据

DELETE[FROM]table[WHEREcondition];

--删除一条数据deletefromdeptwheredeptno=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语句回滚到创建的保存点。

updateempsetsal=sal+100whereempno=7369;savepointupdate_empno7369;deletefromempwhereempno=7369;rollbacktoupdate_empno7369;

五、创建和管理表

常见的数据库对象
如下:
表 基本的数据存储集合,由行和列组成。
视图 从表中抽出的逻辑上相关的数据集合。
序列 提供有规律的数值。
索引 提高查询的效率。
同义词 给对象起别名。

创建表

CREATETABLE[schema.]table(columndatatype[DEFAULTexpr][,...]);

createtabletest(idnumber(12),namevarchar2(32));

通过子查询创建表

CREATETABLEtable[(column,column...)]ASsubquery;

createtabletest2asselectempno,enamefromempwheresal>1000;

修改表

--添加列ALTERTABLEtableADD(columndatatype[DEFAULTexpr][,columndatatype]...);--添加info列altertabletestadd(infovarchar2(256)default'');--修改列ALTERTABLEtableMODIFY(columndatatype[DEFAULTexpr][,columndatatype]...);--修改info列altertabletestmodify(infovarchar2(64)default'');--删除列ALTERTABLEtableDROPcolumn(column);--删除info列altertabletestdropcolumninfo;--修改列名ALTERTABLEtablerenamecolumnold_column_nametonew_column_name;--修改name列名altertabletestrenamecolumnnametoname2;

删除表

1、数据和结构都被删除
2、所有正在运行的相关事物被提交
3、所有相关索引被删除
4、DROP TABLE语句不能回滚,但是可以闪回。

droptabletest;

改变对象的名称

renamedepttonewDept;

清空表
1、删除表中所有数据。
2、释放表的存储空间。
3、truncate不能回滚。

truncatetabletest;

看完上述内容,你们掌握怎么在oracle中查询操作子查询的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!