八宝书库 > 文学其他电子书 > oracle从入门到精通(PDF格式) >

第12部分

oracle从入门到精通(PDF格式)-第12部分

小说: oracle从入门到精通(PDF格式) 字数: 每页4000字

按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!




  GROUPING SETS  

  可以使用 GROUPING SETS 在同一个语句中定义多个组集。  

  只需要访问一次基表。  

  不需要写很复杂的 UNION 语句。  

  GROUPING SETS 子句中组合的元素越多,语句的执行性能就越好。  

  group by GROUPING SETS((abc);(ab);(bc);(a);(b))   

  组合列:  

  是一个列的组合,在分组计算时被作为一个单元处理。  

    



                                    第 43 页,共 106 页 


…………………………………………………………Page 44……………………………………………………………

资源来自网络,仅供学习!                                                  Oracle 从入门到精通 



2。9 高级子查询  



1。   成对子查询:  



  行内视图的性能比成对子查询的性能高。  

相关子查询:  

  主查询的字段在子查询里做条件(特征)。  

  主查询先执行,取出第一条数据,把该数据传入子查询做比较,返回查询结果给主查询,主查 

  询根据这个结果再做查询  

  依次类推  

  直到主查询中没有可查询列为止。  

    

  EXISTS 操作符  

  EXISTS 操作符测试子查询的结果是否存在;  

  返回 TRUE 或 FALSE  

  查询机制:  

  如果一个子查询找到了结果:  

  在内部子查询中不在继续执行,条件被设为 TRUE  

  如果一个子查询没有找到结果:条件被设为 FALSE  

    

  select col_list from table_name tab_alias  

  where exists (select 'x' from table_name where col=tab_alias。col);  

  用的是相关子查询  

  NO EXISTS 操作符  

  和 NOT IN 相对应,速度要快,性能好。  

  UPDATE 中的相关子查询  

  update emp e  

  set department_name in(select d。department_name from departments d where  

  e。department_id=d。department_id);  

    

  delete 中的相关子查询  

    



2。层次查询  



  select 'level';column;expr from table 'where condition'  

  'start with'起点(自底向上/自顶向下)  

  'connect by prior + 主键/外键=外键/主键'//看你往哪个方向查  

  自顶向下 左边放主键,右边放外键  

  select employee_id;last_name;salary;job_id;manager_id  

  from employees  

  start with manager_id is null  

  connect by prior employee_id=manager_id;  

  自底向上 右边放主键,左边放外键  

  level(伪列)  

  层次的级别:不固定值。  



                               第 44 页,共 106 页 


…………………………………………………………Page 45……………………………………………………………

资源来自网络,仅供学习!                                                      Oracle 从入门到精通 



  使用 level 和 LPAD 层次化格式的显示  

  修剪分支  

    

  Oracle 9i 对 DML 和DDL 语句的扩展  

  多表插入的 INSERT 语句   

  insert 。。。。 select 语句可以被用来在单个 DML 语句中向多个表插入数据。  

  多表插入语句:  

  无条件 INSERT  

  条件 ALL INSERT  

  条件 FIRST INSERT  

  轮巡 INSERT   

    



二、Management:  



1。Oracle的构件和组件  



  instance 实例/例程  

  database 数据库  

  SGA  系统全局区  

  shared pool  共享池  

  library cache  库高速缓存区  

  data dictionary cache 字典高速缓存区  

  database buffer cache  数据库高速缓存区  

  redo log buffer 重做日志缓冲区  

  java pool     java 池  

  large pool   大池  

  PMON   进程监视进程  

  SMON   系统监视进程  

  DBWR  数据库写进程  

  LGWR  日志写进程  

  CKPT    检查点进程  

  data file  数据文件  

  control file  控制文件  

  redo log file  重做日志文件  

  parameter file  初始化参数文件  

  password file   口令文件  

  archived log file  归档日志文件  

  user process  用户进程  

  server process  服务进程  

  PGA   程序全局区  

  tablespace 表空间  



                                 第 45 页,共 106 页 


…………………………………………………………Page 46……………………………………………………………

资源来自网络,仅供学习!                                       Oracle 从入门到精通 



2。数据库的物理结构:  



1。控制文件  



2。   数据文件  



3。   重做日志文件  



4。   data file  数据文件:  



5。   作用:存放数据。  



6。   数据文件大小可以扩展。  



7。 tablespace 表空间:一个或多个数据文件的逻辑组成。  



 一个数据库最少有一个 system 表空间,一个表空间最少有一个数据文件。  



8。   redo log file  重做日志文件  



 重做日志:在数据库中发生的所有改变,改变的每一条信息都叫做一条重做日志信息。  

 存放重做日志信息的文件就叫做重做日志文件。  

 作用:利用日志记录可以恢复损坏的数据库,保证数据的可恢复性。  

 重做日志组:包含一个或多个日志文件。  

 特点:  

 一个数据库最少有两个组,一个组最少有一个组成员。  

 重做日志的大小是固定的。  

 写入方式是顺序写入,按时间。  

 切换(一个写满往下一个写),循环(都写满了就重新回到头组写)。  



 9。   control file  控制文件  



 数据库中的核心文件。  

 存放内容:  

 数据库的名称和编号,数据库的结构信息(数据文件和重做日志文件的地址)  

  当前的 SCN system change number 系统改变号:  

   给系统的每一次改变编号(最后一次同步的 SCN 号)。  

   控制文件的 SCN 号和所有存放数据文件的头部的 SCN 相同。  

   启动的时候,一样启动,不一样恢复。  

 特点:一个数据库最少需要一个控制文件,但一般情况下都会有复用/副本。                  



 10。 parameter file  初始化参数文件  



 非必要文件  

 跟实例有关。  



                         第 46 页,共 106 页 


…………………………………………………………Page 47……………………………………………………………

资源来自网络,仅供学习!                                             Oracle 从入门到精通 



 11。 password file   口令文件  



  非必要文件。  

  作用:做特权身份认证。  

  sysdba/sysoper/普通身份  



 12。 archived log file  归档日志文件  



  非必要文件。  

  内容:  

  重做日志文件(redo log file)内容的备份。  

  作用:使数据库所有的日志都会保留下来。  

 特点:每个重做日志内容都会对应一个归档文件。  

 LOG SEQUENCE 日志序列号:重做日志内容的序列号。  

  非归档日志:  

   没有归档日志文件;  

   性能要好一些;  

  可以选择归档模式或非归档模式。  

   



3。instance 实例/例程  



  启动的步骤:  

  (1)启动实例;  

  实例包含:  

 1。SGA   

  2。后台进程   

  一个实例只有一个 SGA,可以有多个 PGA,建立一次连接(会话)就产生一次PGA。  

   

  ORACLE 的内存结构:  

      SGA 在实例启动的时候分配,是 ORACLE 实例的基本组件; 大小可以动态改变(内部大 

  小)  

         通过 SGA_MAX_SIZE 定义大小(总大小是静态的)  

      PGA 程序全局区(私有区域):在服务进程启动的时候分配。  

   

 PGA 程序全局区  

  是为每个用户进程连接 ORA 数据库提供的内存区域;  

  当进程创建时分配;  

  当进程结束时释放;  

  一个 PGA 只被一个进程使用;  

  包含:有连接的信息  

   

  SGA  系统全局区  

  所有数据库的后台进程和服务进程的共用内存区域。  

  包含:  

  1。shared pool  共享池  



                            第 47 页,共 106 页 


…………………………………………………………Page 48……………………………………………………………

资源来自网络,仅供学习!                                                 Oracle 从入门到精通 



   设置大小的参数:SHARED_POOL_SIZE  

   包含:  

  library cahce  库高速缓存区  

   大小由共享池决定。  

   包含:SQL 语句和 SQLPLUS 文本,分析代码,执行计划  

   存储目的:与性能有关。  

   当两个语句相同的时候不需要重新分析,使用相同的执行计划即可。  

   管理方法:采用 LRU (最近使用算法)least recent used 当空间不足的时候,使用 LRU。  

   结构:  SQL 区域、PL/SQL 区域  

  data dictionary cache 字典高速缓存区  

          内容:最近最多使用的数据字典信息  

          作用:为了能够在分析的时候所需要的字典信息能在内存中找到,避免使用物理 I/O。  

          管理方法:采用 LRU (最近使用算法)                   

     

  2。database buffer cache  数据库高速缓存区  

  单位:块。  

  内容:最近最常数据块  

  作用:减少物理 I/O,提高性能  

  参数:DB_BLOCK_SIZE 决定主数据块的大小。  

 会影响性能;  

  设置后不允许修改;  

  管理方法:采用 LRU (最近使用算法)  

  由独立的自缓冲区组成:  

 DB_CACHE_SIZE  

 CB_KEEP_CACHE_SIZE  

 DB_RECYCLE_CACHE_SIZE  

  可以通过 ALTER SYSTEM 命令动态增加或收缩:  

 ALTER SYSTEM SET DB_CACHE_SIZE =96M;  

         

 redo log buffer 重做日志缓冲区  

 记录了对数据块所作的所有修改。  

  作用:数据库的恢复  

  大小由 LOG_BUFFER 决定。  

 顺序单条写入,批量写出到文件。  

   

  java pool     java 池  

  可选  

  java_pool_size 大小  

  large pool   大池  

  可选  

 减轻共享池的负担。  

   被用于:   1。在共享服务器中的会话的内存需求(UGA);  

             2。I/O 辅助;  

             3。备份恢复操作或 RMAN;  

             4。并行执行的信息缓冲区;  

  large_pool_size 大小  



                              第 48 页,共 106 页 


…………………………………………………………Page 49……………………………………………………………

资源来自网络,仅供学习!                                            Oracle 从入门到精通 



   



4、进程结构  



1。   用户进程:开始于数据库用户请求连接数据库  



2。   服务进程:与 ORA 实例连接,开始于用户会话的建立。  



  分为:    专用服务进程、共享服务进程  

  性能专用更好。  

  利用资源方面共享更好(网站方面)。  



3。   后台进程:当 ORA 实例启动时启动  



  后台进程包含:  

1。PMON   进程监视进程  

  监视用户进程(客户端连接服务器的进程)到服务进程(在服务器端响应用户进程的进程)的 

  连接。  

  创建会话。  

   监视会话是否异常中断,如果中断:PMON 会回滚事务、解锁、释放资源。  



2。SMON   系统监视进程  



  任务:会检测 SCN 号,相等:启动  

  不相等,实例恢复(1)前滚将日志应用  

                   (2)打开数据库  

                   (3)恢复数据库  

         恢复的起点是走后一次 CHECKPOINT 的位置。  

   每 3 秒合并空闲空间  

  释放临时段  

      临时段:暂时存放在排序时中没有空间的字段值。  

         在排序中产生的。  

         数据量大的时候,排序是分成若干块执行的,当字段值排好序之后就放到临时段中。  

   



1。  DBWR  数据库写进程  



  /DBW0/DBWn   n:0…9  

   将脏数据写回到数据文件中。  

   

  当发生以下情况执行:    

  当发生检查点事件的时候,checkpoint  



                            第 49 页,共 106 页 


…………………………………………………………Page 50……………………………………………………………

资源来自网络,仅供学习!                                             Oracle 从入门到精通 



  脏块达到极限值;  

  没有空间的缓冲空间  

  超时  

  RAC PING 请求  

  表空间离线  

  表空间只读  

  在表执行 DROP 或TRUNCATE  

  表空间上执行 BEGIN BACKUP         



2。   LGWR  重作日志写进程  



    把重做日志缓冲区的内容写出到

返回目录 上一页 下一页 回到顶部 0 0

你可能喜欢的