oracle基本查询操作子查询用法实例分析

本文实例讲述了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相关内容感兴趣的读者可查看本站专题:《Oracle常用函数汇总》、《Oracle日期与时间操作技巧总结》及《php+Oracle数据库程序设计技巧总结》

希望本文所述对大家Oracle数据库程序设计有所帮助。

(0)

相关推荐

  • oracle查询语句大全(oracle 基本命令大全一)

    1.create user username identified by password;//建用户名和密码oracle ,oracle 2.grant connect,resource,dba to username;//授权 grant connect,resource,dba,sysdba to username; 3.connect username/password//进入. 4.select table_name,column_name from user_tab_columns

  • oracle常用sql查询语句部分集合(图文)

    Oracle查询语句 select * from scott.emp ; 1.--dense_rank()分析函数(查找每个部门工资最高前三名员工信息) select * from (select deptno,ename,sal,dense_rank() over(partition by deptno order by sal desc) a from scott.emp) where a<=3 order by deptno asc,sal desc ; 结果: --rank()分析函数(

  • ORACLE查询删除重复记录三种方法

    比如现在有一人员表 (表名:peosons) 若想将姓名.身份证号.住址这三个字段完全相同的记录查询出来 复制代码 代码如下: select p1.*   from persons  p1,persons  p2   where p1.id<>p2.id   and  p1.cardid = p2.cardid and p1.pname = p2.pname and p1.address = p2.address 可以实现上述效果. 几个删除重复记录的SQL语句 1.用rowid方法 2.用g

  • oracle基本查询用法入门示例

    本文实例讲述了oracle基本查询用法.分享给大家供大家参考,具体如下: 一.基本select语句 SELECT *|{[DISTINCT] column|expression [alias], ...} FROM table; 例如: --查询所有数据 select * from emp; --查询指定列数据 select empno,ename,sal from emp; --算数运算符(+ - * /) select ename,sal,sal+30 from emp; --使用括号 se

  • Oracle数据库中基本的查询优化与子查询优化讲解

    1. 查询条件合理排序 Oracle采用自下而上的顺序解析WHERE字据,从优化性能角度考虑,建议将那些可以过滤掉大量记录行的条件写在WHERE子句的末尾,而将表 之间的连接条件置于其他WHERE子句之前,即对易排查的条件先做判断处理,这样在过滤掉尽可能多的记录后再进行等值连接,可以提高检索效率. 例如: SELECT empno, ename, job, sal, dept.deptno, dname FROM emp, dept WHERE emp.deptno = dept.deptno

  • oracle 查询表名以及表的列名

    1.查询表名: 复制代码 代码如下: select table_name,tablespace_name,temporary from user_tables [where table_name=表名] 其中:table_name:表名(varchar2(30)); tablespace_name:存储表名的表空间(varchar2(30)): temporary:是否为临时表(varchar2(1)). eg: select table_name,tablespace_name,tempora

  • Oracle基础学习之子查询

    首先使用子查询的时候注意事项包括,子查询可以嵌套多层和子查询需要圆括号()括起来,下面我们来看看详细的介绍. 基础介绍 1,wherer:子查询一般会返回单行单列 单行多列 多行单列 : 2,having:子查询会返回单行单列,同时表示要使用统计函数: 3,from:子查询返回多行多列数据(表结构): 4,select:返回单行单列 (一般不使用): 示例详解 where(进行数据行的筛选操作): a:查询出低于公司平均工资的雇员信息. select * from emp where sal<(

  • 一个oracle+PHP的查询的例子

    http://qdlover.yeah.net   一个oracle+PHP的查询的例子   本来我不用php了,可是还是有很多朋友问我,我就做了一个例子,具体函数请查手册   其实oracle的函数和别的也差不多,只不过它这里多了一个定义输出变量的过程,   如果学过pl/sql的人都知道的(不过听说只有清华和西安交大用它做网站).   就是OCIDefineByName($id,"ROWNUM",&$rownum);对应了查询中的rownum,一个对应一个,   而且最应该

  • Oracle通过递归查询父子兄弟节点方法示例

    前言 说到Oracle中的递归查询语法,我觉得有一些数据库基础的童鞋应该都知道,做项目的时候应该也会用到,下面本文就来介绍下关于Oracle通过递归查询父子兄弟节点的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 方法如下: 1.查询某节点下所有后代节点(包括各级父节点) // 查询id为101的所有后代节点,包含101在内的各级父节点 select t.* from SYS_ORG t start with id = '101' connect by parent_

  • Oracle 11GR2的递归WITH子查询方法

    下面给大家详细介绍Oracle 11GR2的递归WITH子查询方法,具体内容如下所示: SQL> with emp_data(ename,empno,mgr,l) as (select ename, empno, mgr, 1 lvl from emp where mgr is null union all select emp.ename, emp.empno, emp.mgr, ed.l+1 from emp, emp_data ed where emp.mgr = ed.empno ) S

  • oracle数据库常用的99条查询语句

    1. select * from emp; 2. select empno, ename, job from emp; 3. select empno 编号, ename 姓名, job 工作 from emp; 4. select job from emp; 5. select distinct job from emp; 6. select distinct empno, job from emp;说明:因为雇员编号不重复, 所以此时证明所有的列没有重复,所以不能消除掉重复的列. 7. 查询

随机推荐