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

53次阅读
没有评论

共计 3569 个字符,预计需要花费 9 分钟才能阅读完成。

自动写代码机器人,免费开通

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

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计3569字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)