Oracle子查询就是嵌套查询,他把select 查询的结果作为另外一个select、update或delete语句的条件,它的本质就是where条件查询中的一个条件表达式。其中我们数据库开发过程中,子查询可以根据查询结果的行数的多少,可以区分为单行子查询和多行子查询。
1、单行子查询:向外部返回的结果为空或者返回一行。
2、多行子查询:向外部返回的结果为空、一行、或者多行。
Oracle单行子查询
Oracle单行子查询是利用where条件“=”关联查询结果的,如果单行子查询返回多行会报单行子查询不能返回多行的数据库错误,下面利用案例讲解子查询。
案例1、查询学生信息表(stuinfo)和班级表(class)中班级为“信息科学2班(18)”的所有学生信息,代码如下:
Oracle多行子查询
Oracle多行子查询则需要利用IN关键字来接收子查询的多行结果。也可以用量化关键字ANY、ALL和关系运算符>、>=、=、<、<=来组合使用。
ANY关键字:表示子查询结果当中的任意一个。假如:>ANY(子查询),表示:只要大于子查询当中的任意一个值,这个条件就满足。
ALL关键字:表示子查询中的所有结果。假如:>ALL(子查询),表示:必须大于子查询当中的所有结果才能满足这个条件。
案例2、查询班级表中所有班级的学生信息。代码如下:
select * from stuinfo t where t.classno in (select b.classno from class b);
案例3、ANY/ALL关键字案例展示,代码如下:
--年龄只要大于当中子查询的最小值26岁即可select * from stuinfo t where t.age>any(26,27,28);--年龄必须大于子查询当中的最大值28岁才可以select * from stuinfo t where t.age>all(26,27,28);
今天简单介绍一下SGA 的设置方法
1.sga_target 参数
alter system set sga_target = 40000m scope=both;
特性:
1).ASMM 自动共享内存管理
答:SGA_TARGET参数控制ASMM(自动共享内存管理)是Oracle一个新特性,但是它的含义和SGA_MAX_SIZE的一样,也表示SGA最大的大小,于是它也就有了一个限制,那就是它的大小不能大于SGA_MAX_SIZE的大小,一旦给SGA_TARGET指定值后(默认为0,即没有启动ASMM),就自动启动了ASMM特性
2).sga_target 与sga_max_size关系
答:即当SGA_TARGET< SGA_MAX_SIZE的时候,oracle就会忽略SGA_MAX_SIZE的值,oracle的SGA就与SGA_TARGET为准,它能动态改变大小,但是不能大于SGA_MAX_SIZE的值,可以小于。
3).sga_target 动态参数
答:SGA_TARGET是可以在本实例内动态修改的,不用重启数据库实例,所谓的动态参数是指可以直接修改即在内存生效,不用重启数据库来加载参数文件生效。
4).ASMM 自动共享内存管理会影响哪些内存区呢
答:当启用Oracle的ASMM新特性以后,也不是SGA的所有内存区的大小都开始动态共享起来,只有以下的这些区的内存大小可动态共享,而SGA中的其他区域的内存大小仍然是固定不共享的
* Buffer cache (DB_CACHE_SIZE)
* Shared pool (SHARED_POOL_SIZE)
* Large pool (LARGE_POOL_SIZE)
* Java pool (JAVA_POOL_SIZE)
* Streams pool (STREAMS_POOL_SIZE)
2.sga_max_size参数
alter system set sga_max_size=40000m scope=spfile;
特性:
1).sga_max_size静态参数
它用来控制SGA使用虚拟内存的最大大小,当实例启动后,各个内存区只分配实例所需要的最小大小,在随后的运行过程中,再根据需要扩展他们的大小,而他们的总和大小受到了SGA_MAX_SIZE的限制。“修改SGA_MAX_SIZE的大小,必须要重新启动数据库实例”,因为是静态参数。所谓静态参数是指修改之后即在spfile参数文件里生效,没有在内存里生效,所以必须重启数据库来加载参数文件使其生效
3.db_cache_size参数【数据库缓冲区高速缓存】
alter system set db_cache_size=2000m scope=both;
1).此参数是一个动态参数,用于缓存数据库中正在使用的“有效数据”的内存区,此内存区的大小对数据的检索速度有很大的影响,如果检索的数据在此区内可以找到,那么要比间接到硬盘中找要快的多。所以在系统稳定后可以静态设置此缓冲区的值
4.scope =【memory | spfile | both】
1).如果scope=memory 说明修改的参数只在内存中生效,重启数据库后恢复到原来状态值【用于修改动态参数】
2).如果scope=spfile 说明修改的参数只在参数文件中生效,修改后当前环境是不生效的,必须重启数据库来加载参数文件使其生效【用于修改静态参数】
3).如果scope=both 说明修改的参数在当前环境(内存)和spfile(参数文件)都生效,both=memory+spfile,修改后当前环境生效,重启数据库后也生效。
小结:当我们明白了这些在SGA中很重要的参数时,才能游刃有余的分配我们有限的内存空间,使我们的系统的性能最大化,让oracle跑的更快、更好。(作者 Oracle之路)
Copyright (C) 1999-20120 www.ahcar.com, All Rights Reserved
版权所有 环球快报网 | 联系我们:265 073 543 9@qq.com