一、子查询语法

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基本查询入门(二) 子查询的更多相关文章

  1. ORACLE 多表连接与子查询

    Oracle表连接 SQL/Oracle使用表连接从多个表中查询数据 语法格式: select 字段列表from table1,table2where table1.column1=table2.co ...

  2. 在MySQL中使用子查询和标量子查询的基本用法

    一.MySQL 子查询 子查询是将一个 SELECT 语句的查询结果作为中间结果,供另一个 SQL 语句调用.MySQL 支持 SQL 标准要求的所有子查询格式和操作,也扩展了特有的几种特性.子查询没 ...

  3. 黑马MySQL数据库学习day03 级联 多表查询 连接和子查询 表约束

    /* 存在外键的表 删表限制: 1.先删除从表,再删除主表.(不能直接删除主表,主表被从表引用,尽管实际可能还没有记录引用) 建表限制: 1.必须先建主表,再建从表(没有主表,从表无法建立外键关系) ...

  4. ylb:子查询(嵌套子查询)和子查询(相关子查询)

    ylbtech-SQL Server:SQL Server-子查询(嵌套子查询)和子查询(相关子查询) SQL Server 子查询(嵌套子查询)和子查询(相关子查询). 1,ylb:1,子查询(嵌套 ...

  5. mysql---where子查询、form子查询、exists子查询

    1.什么是子查询? 当一个查询是另一个查询的条件时,称之为子查询. 2.子查询有什么好处? 子查询可以使用几个简单命令构造功能强大的复合命令. 那么,现在让我们一起来学习子查询. 3.where型的子 ...

  6. 相关子查询和嵌套子查询 [SQL Server]

    SQLServer子查询可以分为 相关子查询 和 嵌套子查询 两类.前提,假设Books表如下: 类编号  图书名         出版社               价格-------------- ...

  7. SQL基础--查询之二--连接查询

    SQL基础--查询之二--连接查询

  8. in型子查询陷阱,exists子查询

    in 型子查询引出的陷阱 select goods_id from goods where cat_id in (1,2,3) 直接用id,不包含子查询,不会中陷阱 题: 在ecshop商城表中,查询 ...

  9. mysql优化---in型子查询,exists子查询,from 型子查询

    in型子查询引出的陷阱:(扫更少的行,不要临时表,不要文件排序就快) 题: 在ecshop商城表中,查询6号栏目的商品, (注,6号是一个大栏目) 最直观的: mysql); 误区: 给我们的感觉是, ...

随机推荐

  1. 关于博主noble_

    大家好啊,我是博主noble_,大家叫我noble就行了.我身处上海某初高中连体的市重点,校内OI比较弱. 个人常用OJ是洛谷,BZOJ,POJ,HDU,UVA.名字都叫noble_. 目前noble ...

  2. Spark Standalone模式HA环境搭建

    Spark Standalone模式常见的HA部署方式有两种:基于文件系统的HA和基于ZK的HA 本篇只介绍基于ZK的HA环境搭建: $SPARK_HOME/conf/spark-env.sh 添加S ...

  3. [Illuminate\Database\QueryException] SQLSTATE[HY000] [1045] Access denied for user 'root'@'localhost' (using pas sword: NO) (SQL: select * from information_schema.tables where table_schema = la

    [Illuminate\Database\QueryException] SQLSTATE[HY000] [1045] Access denied for user 'root'@'localhost ...

  4. Code First use dotConnect for MySQL

    http://www.dotblogs.com.tw/yc421206/archive/2014/03/24/144507.aspx dotConnect for MySQL 是一家強大的 3rd C ...

  5. 用strings命令查看kafka-log内容 过滤二进制编码

    kafka的log内容格式还不没怎么了解,想快速浏览消息内容的话,除了使用它自带的kafka-console-consumer.sh脚本,还可以直接去看log文件本身,不过内容里有部分二进制字符,通过 ...

  6. leetcode344

    public class Solution { public string ReverseString(string s) { var list = s.Reverse(); StringBuilde ...

  7. PadLeft 补零

    补零 PadLeft -Caption.Length())+Caption; UnicodeString __fastcall StringOfChar(WideChar Ch, int Count) ...

  8. 用FireDAC获取 SQL SERVER错误文本信息

    SQL SERVER获取错误文本信息,BDE.adoquery一直取不到,FDQuery可以了 Some DBMS, like SQL Server, return messages as an ad ...

  9. VBA 编写类

    一.初识类 现在,请打开你的VBE,主菜单-插入-类模块. 插入了一个类模块,也就建立了一个类.类模块的名字就是类的名字.你现在看到的,她的名字叫“类1”,这是VBA按她姐妹排行给她取的的,是的,VB ...

  10. Oracle SQL Developer在进行查询的时候只显示50条数据

    在查询结果大于50条的时候,软件默认会只显示50条,向下拉会继续显示. 想要显示所有结果的话,光标放在结果集:ctrl+End或者是ctrl+PgDn都可以.