oracle基本查询操作子查询用法实例分析
本文实例讲述了oracle基本查询操作子查询用法。分享给大家供大家参考,具体如下:
一、子查询语法
SELECTselect_list FROMtable WHEREexproperator(SELECTselect_listFROMtable);
子查询在主查询之前一次执行完成。
子查询的结果被主查询使用。
selectenamefromempwheresal>(selectsalfromempwhereename='SCOTT');
(*注意:子查询要包含在括号内,将子查询放在比较条件的右侧。单行操作符对应单行子查询,多行操作符对应多行子查询。)
单行子查询,只返回一行,使用单行比较符(>=<>=<=!=<>)
--子查询中使用组函数 selectename,salfromempwheresal=(selectmin(sal)fromemp); --子查询中的having子句 --首先执行子查询 --向主查询中的having子句返回结果 selectdeptno,min(sal) fromemp groupbydeptno havingmin(sal)>(selectmin(sal)fromemp);
多行子查询,返回多行,使用多行比较符(INANYALL)
--查询比部门10里任意一个人工资高的员工信息 selectename,sal fromemp wheresal>any(selectsalfromempwheredeptno=10); --查询比部门20里所有人工资高的员工信息 selectename,sal fromemp wheresal>all(selectsalfromempwheredeptno=20); --查询不是老板的员工信息 selectenamefromempwhereempnonotin(selectmgrfromemp);
二、集合运算
并集
UNION运算符返回两个集合去掉重复元素后的所有记录。
UNIONALL返回两个集合的所有记录,包括重复的。
交集
INTERSECT运算符返回同时属于两个集合的记录
--返回工资在500-1000和900-1200的员工信息 selectename,sal fromemp wheresalbetween500and1000 intersect selectename,sal fromemp wheresalbetween900and1200;
差集
MINUS返回属于第一个集合,但不属于第二个集合的记录。
--返回工资属于500-1000,但不属于900-1200的员工信息 selectename,sal fromemp wheresalbetween500and1000 minus selectename,sal fromemp wheresalbetween900and1200;
集合使用的注意事项
1、select语句中参数类型和个数保持一致。
2、可以使用括号改变集合执行的顺序。
3、如果有orderby,必须放到最后一句查询语句后。
4、集合运算采用第一个语句的表头作为表头。
三、数据操作语言
插入数据
INSERTINTOtable[(column[,column...])] VALUES(value[,value...]);
insertintodept(deptno,dname,loc)values(50,'test','test');
从其他表中拷贝数据
insertintodept(deptno,dname,loc) select60,dname,locfromdeptwheredeptno=10;
更新数据
UPDATEtable SETcolumn=value[,column=value,...] [WHEREcodition]
--更新一条数据 updateempsetsal=sal+100whereempno=7369;
--update使用子查询 updateemp setsal=(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语句的执行作为开始
以下面的其中之一作为结束:
显示结束:commitrollback
隐式结束(自动提交):DDL语句,DCL语句,exit(事务正常退出)
隐式回滚(系统异常终了):关闭窗口,死机,掉电
commit和rollback语句的优点
1、确保数据完整性。
2、数据改变被提交之前预览。
3、将逻辑上相关的操作分组。
回滚到保留点
使用savepoint语句在当前事务中创建保存点。
使用rollbacktosavepoint语句回滚到创建的保存点。
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;
修改表
--添加列 ALTERTABLEtable ADD(columndatatype[DEFAULTexpr][,columndatatype]...); --添加info列 altertabletestadd(infovarchar2(256)default''); --修改列 ALTERTABLEtable MODIFY(columndatatype[DEFAULTexpr][,columndatatype]...); --修改info列 altertabletestmodify(infovarchar2(64)default''); --删除列 ALTERTABLEtable DROPcolumn(column); --删除info列 altertabletestdropcolumninfo; --修改列名 ALTERTABLEtable renamecolumnold_column_nametonew_column_name; --修改name列名 altertabletestrenamecolumnnametoname2;
删除表
1、数据和结构都被删除
2、所有正在运行的相关事物被提交
3、所有相关索引被删除
4、DROPTABLE语句不能回滚,但是可以闪回。
droptabletest;
改变对象的名称
renamedepttonewDept;
清空表
1、删除表中所有数据。
2、释放表的存储空间。
3、truncate不能回滚。
truncatetabletest;
更多关于Oracle相关内容感兴趣的读者可查看本站专题:《Oracle常用函数汇总》、《Oracle日期与时间操作技巧总结》及《php+Oracle数据库程序设计技巧总结》
希望本文所述对大家Oracle数据库程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。