千家信息网

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

发表于:2024-09-22 作者:千家信息网编辑
千家信息网最后更新 2024年09月22日,怎么在oracle中查询操作子查询?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一、子查询语法SELECT select_listFRO
千家信息网最后更新 2024年09月22日怎么在oracle中查询操作子查询

怎么在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中查询操作子查询的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注行业资讯频道,感谢各位的阅读!

查询 数据 语句 信息 员工 多行 事务 工资 运算 两个 对象 数据库 内容 子句 括号 操作符 方法 更多 空间 索引 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 软件开发的第一要义是可信 曲靖新华互联网科技价格 上海计算机软件开发代码 昆明 软件开发报价 成都农业erp软件开发 辽宁网络技术基础书 论述软件开发的基本流程 企业公网服务器备案 数据库死锁的预防机制主要有 数据库中怎么储存文章 备份失败连接服务器时出现问题 t6数据库没启动 软件开发超过时间 武汉机架式服务器 蚌埠库存软件开发平台 蓝思科技和工业互联网 为什么苹果账户无法连接服务器 认证时出现服务器ip连接失败 南京柯邦网络技术有限公司 青岸软件开发工作室 艾尔登法环为什么登不上服务器 网络安全运维工程师工作内容 聊天软件开发平台 广西竺日网络技术有限公司 看护苗网络安全有感 互联网保险平台科技型企业 聚焦网络技术公司 青岸软件开发工作室 阿勒泰全力做好两会期间属地网络安全工作 服务器出现滴滴警报声
0