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

来源:脚本之家  责任编辑:小易  

--查询“叶平”老师的课堂,以及成绩最高的学生的名字?--第一种SELECT TC.COURSENA

本文实例讲述了oracle基本查询操作子查询用法。分享给大家供大家参考,具体如下:

每个部门俯场碘渡鄢盗碉醛冬互大于所有人平均工资的员工:Select BM,YG From TB WH

一、子查询语法

xml 类型的时候可以使用any 关键字和子查询,返回的结果是xml结构的;select *

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

SELECT select_list FROM table WHERE expr operator (SELECT select_list FROM table);

除了内置系统函数和limit谓词不一样外,对于选择查询来说,这两种数据库在基本的子查询和多表查询语法

子查询在主查询之前一次执行完成。

高加索犬vs藏獒,哪个更厉害?下面是一段真实的故事:  电视台拍节目的时候发生了意外,KB\"巨灵神\"对藏獒\"魔王\"发出致命一击.一口卡住魔王喉咙,喉咙被咬一个洞,上了三瓶云南白药,打了两支止血敏,现在垂危中,而整个过程不足5分钟。见面打个招呼,好像要亲嘴的样子突然藏獒就对高加索发火了,奈何‘小高’完全不了它‘小高’终于忍不住挑衅还手了瞬间两狗扭打在一起,家长过来拉架藏獒被一口咬住了脖子瞬间藏獒被KO!!!!!!!!!!!!!!!!!!!!!!!!

子查询的结果被主查询使用。

不知道你玩的是什么游戏保险起见给你加了一个机械硬盘。I37100单核很强适合玩游戏再搭配GTX1050Ti4G基本上可以畅玩所有游戏了。显示器700说贵也不贵说便宜也不便宜,购买的时候记得问下客服包括接口之类的东西,看介绍有HDMI接口,参考以下配置即可。CPU:INTELi37100散605主板:微星B250MPROVD500显卡:微星GTX1050Ti飙风4G1080内存:威刚DDR424008G420固态:宇瞻黑豹120G340硬盘:WD1T64M蓝盘278散热:九州风神玄冰30059电源:全汉额定450W铜牌250机箱:航嘉暗夜猎手290显示器:AOC22IPS无边框I2279VW70

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

select ename from emp where sal > (select sal from emp where ename='SCOTT');

谢谢邀请回答,是的,确实有10元的人民币值20元的。小编就说说第二遍人民币中的10元拾圆工农像(大黑拾)在第二套人民币中,大黑拾已经成为名副其实的“大黑马”,一张纸币可以卖到二十万左右。下面小编顺便把第二版其他面额的RMB,某网址2017年8月发布的收购价格,转载供宝宝们参考单张(1张),整刀(100张),整捆(1000张),整包(10000张),整麻袋(100000张)壹分长号码8800全品整刀贰分长号码7600全品整刀伍分长号码20-200-1200全品单张黄壹角拖拉机100-500全品单张贰角火车100-1300全品单张伍角水电站无水印100-350整刀/整捆说到53年的五角纸币,很多人

(*注意:子查询要包含在括号内,将子查询放在比较条件的右侧。单行操作符对应单行子查询,多行操作符对应多行子查询。)

单行子查询,只返回一行,使用单行比较符(> = < >= <= != <>)

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

--子查询中使用组函数 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)

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

--查询比部门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、集合运算采用第一个语句的表头作为表头。

三、数据操作语言

插入数据

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

INSERT INTO table [(column [,column...])] VALUES (value [,value...]);

insert into dept(deptno,dname,loc) values(50,'test','test');

从其他表中拷贝数据

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

insert into dept(deptno, dname, loc) select 60, dname, loc from dept where deptno = 10;

更新数据

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

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));

删除数据

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

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语句回滚到创建的保存点。

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

update emp set sal=sal+100 where empno=7369; savepoint update_empno7369; delete from emp where empno=7369; rollback to update_empno7369;

五、创建和管理表

常见的数据库对象

如下:

表        基本的数据存储集合,由行和列组成。

视图     从表中抽出的逻辑上相关的数据集合。

序列     提供有规律的数值。

索引     提高查询的效率。

同义词  给对象起别名。

创建表

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

CREATE TABLE [schema.]table (column datatype [DEFAULT expr][, ...]);

create table test( id number(12), name varchar2(32));

通过子查询创建表

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

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语句不能回滚,但是可以闪回。

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

drop table test;

改变对象的名称

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

rename dept to newDept;

清空表

1、删除表中所有数据。

2、释放表的存储空间。

3、truncate不能回滚。

第一次的rownum是oracle中的一个虚拟列你说的rn是给这个rownum起的别名,也就是在

truncate table test;

更多关于Oracle相关内容感兴趣的读者可查看本站专题:《Oracle常用函数汇总》、《Oracle日期与时间操作技巧总结》及《php+Oracle数据库程序设计技巧总结

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

扩展阅读,根据您访问的内容系统为您准备了以下内容,希望对您有帮助。

oracle关于sql子查询怎么把外面的参数传到子查询里面作为判断条件(不用函数)

给你几个建议

1.子查询不一定能解决你所有问题,一般的子查询都可以用关联替代,比如你这个例子,直接tablA和tablB关联就可以了。在部分sql语句中使用关联方法(包括外关联),可以有效提高效率。

2.不要想着把所有问题扔给数据库,要后台代码和数据库结合应用,把子查询和主查询分开,利用后台代码来做逻辑判断,该执行哪个查询时,在去执行,参数都有后台代码给出,尽量避免用sql判断逻辑。

3.select a.name,(select b.sex from tablB where a.id = b.id) from tablA a

手头没有sql环境,但是这个sql语句应该是可以执行的,不知道是不是你要的。追问谢谢,第三点就是我想要的,原来可以这样的,我错了

Oracle的用子查询因子化查询count 大于avg(salary)的问题

一、单行子查询:

1、单行子查询指在子查询中只返回单行值,这种子查询需要使用单行比较运算符,包括=、>、>=、<、<=、<>。

2、单行子查询出现在WHERE子句中,如下所示:

3、单行子查询中有分组函数,要求分组函数返回的是单行数据。如下图为查询出薪水比本部门平均薪水高的员工信息:

4、单行子查询出现在HAVING子句中,如下图为查询出平均薪水高于部门30最高薪水的部门信息。

Oracle相关,更新语句中应用子查询,子查询的条件为什么会同时作用到更新操作?

第一句写的最完整,加了存在性限定条件,更新操作时会先去找限定条件,在执行更新操作;第二句没有where限定条件,则用子查询的关联表结果集全部进行更新操作;第三句没有关联查询,则用test3表全部结果集进行更新test1追问第三个sql是会报错的,而第二个却不会,为什么?毕竟第二个也是返回多个值的

oracle单行子查询和多行子查询有什么样的区别,不要说什么一个是单行,一个是多行。。。

不管在什么情况下子查询能够保证放回值是1<=1行,则可采用单行比较符:=、<、>、<=、>=等;

否则要采用多行比较符:IN、> ANY 、> ALL、< ANY、< ALL等。

举例说明:

1、单行子查询 -- 查询部门在'NEW YORK'的所有雇员信息。

SELECT * FROM emp WHERE deptno=(SELECT deptno FROM dept WHERE loc='NEW YORK');

语句中子查询SELECT deptno FROM dept WHERE loc='NEW YORK'的返回确定只有一个。

2、多行子查询 -- 查询工资低于2000的雇员所属部门名称。

SELECT * FROM dept WHERE deptno IN (SELECT deptno FROM emp WHERE sal<2000);

语句中子查询SELECT deptno FROM emp WHERE sal<2000佣金小于2000的部门不能确定有几个,因此,采用多行比较符IN。

  • 本文相关:
  • oracle 11gr2的递归with子查询方法
  • oracle基础学习之子查询
  • oracle数据库中基本的查询优化与子查询优化讲解
  • oracle通过递归查询父子兄弟节点方法示例
  • 一个oracle+php的查询的例子
  • oracle基本查询用法入门示例
  • oracle 查询表名以及表的列名
  • oracle查询语句大全(oracle 基本命令大全一)
  • oracle数据库常用的99条查询语句
  • oracle查询删除重复记录三种方法
  • oracle常用sql查询语句部分集合(图文)
  • oracle触发器trigger详解
  • oracle基础:通过sqlplus执行sql语句后的结果进行判断
  • oracle一个用户如何访问其它用户的表应用指南
  • oracle 树查询 语句
  • oracle 启动例程 startup参数说明
  • 详解oracle修改字段类型方法总结
  • oracle 数据 使用游标
  • proc 连接oracle代码
  • oracle中110个常用函数介绍
  • 解决navicat 链接oracle时出现的各种问题
  • oracle关于sql子查询怎么把外面的参数传到子查询里面作为判断条件(不用函数)
  • Oracle的用子查询因子化查询count 大于avg(salary)的问题
  • Oracle相关,更新语句中应用子查询,子查询的条件为什么会同时作用到更新操作?
  • oracle单行子查询和多行子查询有什么样的区别,不要说什么一个是单行,一个是多行。。。
  • oracle子查询中能使用order by吗
  • oracle子查询无法引用外部表的列,提示标识符无效。
  • Oracle数据库中 查询高于自己部门平均工资的员工信息 用相关子查询怎么做啊?
  • oracle中pivot子查询如何用
  • oracle 分页查询 为什么第一次子查询用rownum,第二次用rn,其他方式都不可以呢?
  • MySQL与Oracle的子查询和多表查询区别 求大神求好心人!!!!!!!!!!
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页oracleoracle常用函数汇总oracle日期与时间操作技巧总结php+oracle数据库程序设计技巧总结oracle 11gr2的递归with子查询方法oracle基础学习之子查询oracle数据库中基本的查询优化与子查询优化讲解oracle通过递归查询父子兄弟节点方法示例一个oracle+php的查询的例子oracle基本查询用法入门示例oracle 查询表名以及表的列名oracle查询语句大全(oracle 基本命令大全一)oracle数据库常用的99条查询语句oracle查询删除重复记录三种方法oracle常用sql查询语句部分集合(图文)oracle触发器trigger详解oracle基础:通过sqlplus执行sql语句后的结果进行判断oracle一个用户如何访问其它用户的表应用指南oracle 树查询 语句oracle 启动例程 startup参数说明详解oracle修改字段类型方法总结oracle 数据 使用游标proc 连接oracle代码oracle中110个常用函数介绍解决navicat 链接oracle时出现的各种问题oracle 查看表空间的大小及使用情linux系统(x64)安装oracle11g完oracle数据库下载及安装图文操作oracle存储过程基本语法介绍oracle 10g 安装教程[图文]oracle 如何查询被锁定表及如何解基于ora-12170 tns 连接超时解决oracle数据库tns配置方法详解oracle 创建表空间详细介绍oracle中to_date详细用法示例(ororacle 多参数查询语句oracle 11gr2 win64安装配置教程另附基本基于oracle的面向对象技术入门基础简析开oracle 11g用户修改密码及加锁解锁功能实oracle 忘记密码的找回方法oracle中通配符和运算符的使用方法介绍oracle 获取表注释和列注释oraclepl/sql单行函数和组函数详解oracle 中 decode 函数用法oracle中文乱码的解决方法
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved