﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-The important thing in life is to have a great aim , and the determination -随笔分类-数据库</title><link>http://www.blogjava.net/tjyhy590/category/54315.html</link><description /><language>zh-cn</language><lastBuildDate>Sun, 25 May 2014 09:03:08 GMT</lastBuildDate><pubDate>Sun, 25 May 2014 09:03:08 GMT</pubDate><ttl>60</ttl><item><title>8种Nosql数据库系统对比</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/23/414011.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Fri, 23 May 2014 03:19:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/23/414011.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/414011.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/23/414011.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/414011.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/414011.html</trackback:ping><description><![CDATA[1. CouchDB <br />&#8226;所用语言： Erlang <br />&#8226;特点：DB一致性，易于使用 <br />&#8226;使用许可： Apache <br />&#8226;协议： HTTP/REST <br />&#8226;双向数据复制， <br />&#8226;持续进行或临时处理， <br />&#8226;处理时带冲突检查， <br />&#8226;因此，采用的是master-master复制（见编注2） <br />&#8226;MVCC &#8211; 写操作不阻塞读操作 <br />&#8226;可保存文件之前的版本 <br />&#8226;Crash-only（可靠的）设计 <br />&#8226;需要不时地进行数据压缩 <br />&#8226;视图：嵌入式 映射/减少 <br />&#8226;格式化视图：列表显示 <br />&#8226;支持进行服务器端文档验证 <br />&#8226;支持认证 <br />&#8226;根据变化实时更新 <br />&#8226;支持附件处理 <br />&#8226;因此， CouchApps（独立的 js应用程序） <br />&#8226;需要 jQuery程序库 <br />最佳应用场景：适用于数据变化较少，执行预定义查询，进行数据统计的应用程序。适用于需要提供数据版本支持的应用程序。 例如： CRM、CMS系统。 <br />master-master复制对于多站点部署是非常有用的。 （编注2：master-master复制：是一种数据库同步方法，允许数据在一组计算机之间共享数据，<br />并且可以通过小组中任意成员在组内进行数据更新。） <br /><br />2. Redis <br />&#8226;所用语言：C/C++ <br />&#8226;特点：运行异常快 <br />&#8226;使用许可： BSD <br />&#8226;协议：类 Telnet <br />&#8226;有硬盘存储支持的内存数据库， <br />&#8226;但自2.0版本以后可以将数据交换到硬盘（注意， 2.4以后版本不支持该特性！） <br />&#8226;Master-slave复制（见编注3） <br />&#8226;虽然采用简单数据或以键值索引的哈希表，但也支持复杂操作，例如 ZREVRANGEBYSCORE。 <br />&#8226;INCR &amp; co （适合计算极限值或统计数据） <br />&#8226;支持 sets（同时也支持 union/diff/inter） <br />&#8226;支持列表（同时也支持队列；阻塞式 pop操作） <br />&#8226;支持哈希表（带有多个域的对象） <br />&#8226;支持排序 sets（高得分表，适用于范围查询） <br />&#8226;Redis支持事务 &#8226;支持将数据设置成过期数据（类似快速缓冲区设计） <br />&#8226;Pub/Sub允许用户实现消息机制 <br />最佳应用场景：适用于数据变化快且数据库大小可遇见（适合内存容量）的应用程序。 例如：股票价格、数据分析、实时数据搜集、实时通讯。 <br />（编注3：Master-slave复制：如果同一时刻只有一台服务器处理所有的复制请求，这被称为 Master-slave复制，通常应用在需要提供高可用性的服务器集群。）<br /><br />&nbsp;3. MongoDB <br />&#8226;所用语言：C++ <br />&#8226;特点：保留了SQL一些友好的特性（查询，索引）。 <br />&#8226;使用许可： AGPL（发起者： Apache） <br />&#8226;协议： Custom, binary（ BSON） <br />&#8226;Master/slave复制（支持自动错误恢复，使用 sets 复制） <br />&#8226;内建分片机制 <br />&#8226;支持 javascript表达式查询 <br />&#8226;可在服务器端执行任意的 javascript函数 <br />&#8226;update-in-place支持比CouchDB更好 <br />&#8226;在数据存储时采用内存到文件映射 <br />&#8226;对性能的关注超过对功能的要求 <br />&#8226;建议最好打开日志功能（参数 &#8211;journal） <br />&#8226;在32位操作系统上，数据库大小限制在约2.5Gb <br />&#8226;空数据库大约占 192Mb <br />&#8226;采用 GridFS存储大数据或元数据（不是真正的文件系统） <br />最佳应用场景：适用于需要动态查询支持；需要使用索引而不是 map/reduce功能；需要对大数据库有性能要求；需要使用 CouchDB但因为数据改变太频繁而占满内存的应用程序。 例如：你本打算采用 MySQL或 PostgreSQL，但因为它们本身自带的预定义栏让你望而却步。 <br /><br />4. Riak<br />&nbsp;&#8226;所用语言：Erlang和C，以及一些Javascript <br />&#8226;特点：具备容错能力 <br />&#8226;使用许可： Apache <br />&#8226;协议： HTTP/REST或者 custom binary <br />&#8226;可调节的分发及复制(N, R, W) <br />&#8226;用 JavaScript or Erlang在操作前或操作后进行验证和安全支持。 <br />&#8226;使用JavaScript或Erlang进行 Map/reduce <br />&#8226;连接及连接遍历：可作为图形数据库使用 <br />&#8226;索引：输入元数据进行搜索（1.0版本即将支持） <br />&#8226;大数据对象支持（ Luwak） <br />&#8226;提供&#8220;开源&#8221;和&#8220;企业&#8221;两个版本 <br />&#8226;全文本搜索，索引，通过 Riak搜索服务器查询（ beta版） <br />&#8226;支持Masterless多站点复制及商业许可的 SNMP监控 <br />最佳应用场景：适用于想使用类似 Cassandra（类似Dynamo）数据库但无法处理 bloat及复杂性的情况。适用于你打算做多站点复制，但又需要对单个站点的扩展性，可用性及出错处理有要求的情况。 例如：销售数据搜集，工厂控制系统；对宕机时间有严格要求；可以作为易于更新的 web服务器使用。<br />&nbsp;<br />5. Membase <br />&#8226;所用语言： Erlang和C <br />&#8226;特点：兼容 Memcache，但同时兼具持久化和支持集群 <br />&#8226;使用许可： Apache 2.0 <br />&#8226;协议：分布式缓存及扩展 <br />&#8226;非常快速（200k+/秒），通过键值索引数据 <br />&#8226;可持久化存储到硬盘 <br />&#8226;所有节点都是唯一的（ master-master复制） <br />&#8226;在内存中同样支持类似分布式缓存的缓存单元 <br />&#8226;写数据时通过去除重复数据来减少 IO <br />&#8226;提供非常好的集群管理 web界面 <br />&#8226;更新软件时软无需停止数据库服务 <br />&#8226;支持连接池和多路复用的连接代理 <br />最佳应用场景：适用于需要低延迟数据访问，高并发支持以及高可用性的应用程序 例如：低延迟数据访问比如以广告为目标的应用，高并发的 web 应用比如网络游戏（例如 Zynga） <br /><br />6. Neo4j <br />&#8226;所用语言： Java <br />&#8226;特点：基于关系的图形数据库 <br />&#8226;使用许可： GPL，其中一些特性使用 AGPL/商业许可 <br />&#8226;协议： HTTP/REST（或嵌入在 Java中） <br />&#8226;可独立使用或嵌入到 Java应用程序 <br />&#8226;图形的节点和边都可以带有元数据 <br />&#8226;很好的自带web管理功能 <br />&#8226;使用多种算法支持路径搜索 <br />&#8226;使用键值和关系进行索引 <br />&#8226;为读操作进行优化 <br />&#8226;支持事务（用 Java api） <br />&#8226;使用 Gremlin图形遍历语言 <br />&#8226;支持 Groovy脚本 <br />&#8226;支持在线备份，高级监控及高可靠性支持使用 AGPL/商业许可 最佳应用场景：适用于图形一类数据。这是 Neo4j与其他nosql数据库的最显著区别 例如：社会关系，公共交通网络，地图及网络拓谱 <br /><br />7. Cassandra <br />&#8226;所用语言： Java <br />&#8226;特点：对大型表格和 Dynamo支持得最好 <br />&#8226;使用许可： Apache <br />&#8226;协议： Custom, binary (节约型) <br />&#8226;可调节的分发及复制(N, R, W) <br />&#8226;支持以某个范围的键值通过列查询 <br />&#8226;类似大表格的功能：列，某个特性的列集合 <br />&#8226;写操作比读操作更快 <br />&#8226;基于 Apache分布式平台尽可能地 Map/reduce <br />&#8226;我承认对 Cassandra有偏见，一部分是因为它本身的臃肿和复杂性，也因为 Java的问题（配置，出现异常，等等） <br />最佳应用场景：当使用写操作多过读操作（记录日志）如果每个系统组建都必须用 Java编写（没有人因为选用 Apache的软件被解雇） 例如：银行业，金融业（虽然对于金融交易不是必须的，但这些产业对数据库的要求会比它们更大）写比读更快，所以一个自然的特性就是实时数据分析 <br /><br />8. HBase （配合 ghshephard使用） <br />&#8226;所用语言： Java <br />&#8226;特点：支持数十亿行X上百万列 <br />&#8226;使用许可： Apache <br />&#8226;协议：HTTP/REST （支持 Thrift，见编注4） <br />&#8226;在 BigTable之后建模 <br />&#8226;采用分布式架构 Map/reduce <br />&#8226;对实时查询进行优化 <br />&#8226;高性能 Thrift网关 <br />&#8226;通过在server端扫描及过滤实现对查询操作预判 <br />&#8226;支持 XML, Protobuf, 和binary的HTTP <br />&#8226;Cascading, hive, and pig source and sink modules <br />&#8226;基于 Jruby（ JIRB）的shell <br />&#8226;对配置改变和较小的升级都会重新回滚 <br />&#8226;不会出现单点故障 <br />&#8226;堪比MySQL的随机访问性能 最佳应用场景：适用于偏好BigTable:)并且需要对大数据进行随机、实时访问的场合。 例如： Facebook消息数据库（更多通用的用例即将出现） <img src ="http://www.blogjava.net/tjyhy590/aggbug/414011.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-23 11:19 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/23/414011.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle 10g内存结构之共享池的相关知识及使用简介</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/17/413794.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Sat, 17 May 2014 15:37:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/17/413794.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413794.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/17/413794.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413794.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413794.html</trackback:ping><description><![CDATA[<p>SGA中的第三个组成部分是共享池。共享池是对sql ,pl/sql 程序进行语法分析、编译、执行的内存区域。共享池包括库缓冲区（library cache）、数据字典缓冲区（Data Directory Cache）用户全局区（User Global Area）。其中库缓冲区含有Sql 语句的分析码、执行计划；数据字典缓冲区含有从数据字典中得到的表、列定义、权限。用户全局区包含用户的MTS 会话信息。</p>
<p>共享池主要用于对SQL 、pl/sql 程序语句进行语法分析、编译、执行、所以，如果应用中药运行大量存储过程或包，则要增加共享池的尺寸。共享池的大小由参数SHARE_POOL_SIZE确定。要了解共享池大小，可以用以下方法：</p>
<p><strong>方法一：</strong></p>
<p>&nbsp;</p><pre><ol class="dp-xml"><li class="alt"><span>&#8230;&#8230;&#8230; &nbsp;</span></li><li><span class="attribute">Shared_Pool_size</span><span>&nbsp;=&nbsp;</span><span class="attribute-value">52428800</span><span>&nbsp;</span></li><li class="alt"><span>&#8230;..&nbsp;</span></li></ol></pre>
<p>&nbsp;</p>
<p><strong>方法二：</strong></p>
<p>&nbsp;</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>&nbsp;select&nbsp;name,value&nbsp;from&nbsp;v$parameter&nbsp;where&nbsp;name&nbsp;like&nbsp;&#8216;%size&#8217;;&nbsp;</span></li></ol></pre>
<p>&nbsp;</p>
<p><strong>方法三：</strong></p>
<p>&nbsp;</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>&nbsp;show&nbsp;parameter&nbsp;share_pool_size&nbsp;</span></li></ol></pre>
<p>&nbsp;</p>
<p>共享池应计算存储过程、包等的成功率。</p>
<p>可以查询数据字典 v$rowcache 了解数据字典的成功与失败次数。</p>
<p>&nbsp;</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>&nbsp;select&nbsp;sum(gets)&nbsp;&#8220;dictionary&nbsp;gets&#8221;, &nbsp;</span></li><li><span>Sum(getmisses)&nbsp;&#8220;dictionary&nbsp;cache&nbsp;getmisses&#8221; &nbsp;</span></li><li class="alt"><span>From&nbsp;v$rowcache&nbsp;;&nbsp;</span></li></ol></pre>
<p>&nbsp;</p>
<p>其中gets 表示读取某一类数据字典的成功次数，getsmisses 表示读取某一类数据字典的失败次数。此外还可以通过查询结果计算共享池中读取数据字典的成功率</p>
<p>&nbsp;</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>&nbsp;select&nbsp;parameter,&nbsp;get,&nbsp;getmisses,&nbsp;getmisses/(getmisses+gets)*100&nbsp;&#8220;miss&nbsp;ratio&#8221;, &nbsp;</span></li><li><span>(1-&nbsp;&nbsp;&nbsp;&nbsp;(sum(getmisses)/(sum(getmisses)+sum(gets))&nbsp;)&nbsp;)&nbsp;*100&nbsp;&#8220;hit&nbsp;ratio&#8221; &nbsp;</span></li><li class="alt"><span>From&nbsp;v$rowcache &nbsp;</span></li><li><span>Where&nbsp;gets+getmisses</span><span class="tag">&lt;</span><span class="tag">&gt;</span><span>0 &nbsp;</span></li><li class="alt"><span>Group&nbsp;by&nbsp;parameter,gets,getmisses;&nbsp;</span></li></ol></pre>
<p>&nbsp;</p>
<p>查询数据字典 v$librarycache 可以计算共享池中库缓存的失败率，结果应该小于1%。</p>
<p>&nbsp;</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>select&nbsp;sum(pins)&nbsp;&#8220;&nbsp;total&nbsp;pins&#8221;,&nbsp;sum(reloads)&nbsp;&#8220;&nbsp;total&nbsp;reloads&#8221;,&nbsp;sum(reloads)/sum(pins)*100&nbsp;libarycache&nbsp;&nbsp;from&nbsp;&nbsp;v$librarycache;&nbsp;</span></li></ol></pre>
<p>&nbsp;</p>
<p>其中 total pins 表示驻留内存的次数， total reloads 表示重新加载到内存的次数，librarycache 表示失败率。</p>
<p>上面分析了系统全局区的三个组成部分-----数据缓冲区、日志缓冲区及共享池，如果要得到SGA的总大小，可以在SQL*Plus中使用show sga 命令。</p>
<p>SQL&gt;show sga或查询数据字典</p>
<p>SQL&gt; select * from v$sga;</p>
<p>如果要查询某个参数的大小，可以查询数据字典v_$sagstat,通过计算可以知道sga的使用空间与空闲空间的比。</p>
<p>&nbsp;</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>col&nbsp;OBJECT_NAME&nbsp;format&nbsp;a20 &nbsp;</span></li><li><span>SQL</span><span class="tag">&gt;</span><span>&nbsp;col&nbsp;空闲空间百分比(%)&nbsp;format&nbsp;90.99 &nbsp;</span></li><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>&nbsp;select&nbsp;name, &nbsp;</span></li><li><span>Sgasize/1024/1024&nbsp;&nbsp;&#8220;allocated(M)&#8221;&nbsp;, &nbsp;</span></li><li class="alt"><span>Bytes/1024&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&#8220;空闲空间(k)&#8221;&nbsp;, &nbsp;</span></li><li><span>Round(bytes/sagsize*100,2)&nbsp;&nbsp;&#8220;空闲空间百分比(%)&#8221; &nbsp;</span></li><li class="alt"><span>From&nbsp;(&nbsp;select&nbsp;sum(bytes)&nbsp;sgasize&nbsp;from&nbsp;sys.v_$sgastat)&nbsp;s&nbsp;,sys.v_$sgastat&nbsp;f &nbsp;</span></li><li><span>Where&nbsp;</span><span class="attribute">f.name</span><span>=&#8217;free&nbsp;memory&#8217;&nbsp;;&nbsp;&nbsp;</span></li></ol></pre>
<p>&nbsp;</p>
<p>关于Oracle 10g内存结构之共享池的相关知识及使用方法就介绍到这里了，希望本次的介绍能够对您有所收获！</p><img src ="http://www.blogjava.net/tjyhy590/aggbug/413794.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-17 23:37 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/17/413794.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle 10g内存结构之系统全局区简介</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/17/413793.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Sat, 17 May 2014 15:31:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/17/413793.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413793.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/17/413793.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413793.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413793.html</trackback:ping><description><![CDATA[<p>我们知道，内存结构是Oracle体系结构中最重要的部分之一。按照系统对内存使用方法的不同，可以分为<strong>系统全局区</strong>（SGA）、程序全局区（PGA）、排序区（Sort Area）、大池（Large Pool）、及java池（java Pool），本文我们先介绍一下<strong>Oracle 10g内存结构</strong>之系统全局区的内容，接下来我们就开始介绍这部分内容。</p>
<p><strong>系统全局区（System Global Area）</strong></p>
<p>它是一组为系统分配的内存共享结构，可以包含一个数据库实例的数据和控制信息。如果多个用户连接到一个实例，在实例的系统全局区中，数据可以被多个用户共享，所以又称共享全局区。系统全局区按其作用不同，可以分为数据缓冲区、日志缓冲区及共享池。</p>
<p><strong>数据缓冲区：</strong></p>
<p>数据缓冲区用于从磁盘读入的数据，供所有用户共享。</p>
<p>修改的数据、插入的数据存储在数据缓冲区中，修改完成或DBWR进程的其他条件引发时，数据被写入数据文件</p>
<p>数据缓冲区工作原理：</p>
<p>LRU （Least recently used）：最近最少使用原则的缩写，是一种数据缓冲区的一种管理机制，，只保留最近数据，不保留旧数据。</p>
<p>Dirty：表示脏数据，脏数据是修改后还没有写到数据文件的数据。</p>
<p>Oracle10g 的数据库内存的设置参数不再由DB_BLOCK_BUFFERS确定，而是由oracle的新参数DB_CACHE_SIZE 和DB_nK_CACHE_SIZE确定，不同的数据段可以使用不同的数据块。大表可以存储在大的数据块表空间中，小表可以存储在小的数据块表空间中，以优化i/o性能。对于系统表空间、临时表空间、及其它默认设置的表空间，可以使用标准的数据块DB_BLOCK_SIZE确定。</p>
<p>标准数据块DB_BLOCK_SIZE用于系统表空间及默认表空间，其他表空间可以使用非标准数据块BLOCKSIZE（创建表空间时使用），其值分别为 2k 4k 8k 16k 32k ，非标准数据块的数据缓冲区使用参数DB_Nk_CACHE_SIZE确定。</p>
<p>需要注意的是BLOCKSIZE不得用于标准块。如果设置了DB_BLOCK_SIZE=2048,则不得设置DB_2K_CACHE_SIZE，标准块必须使用参数DB_CACHE_SIZE 来设置。同时可以在线修改数据缓冲区参数：SQL&gt; alter system set db_2k_cache_size = 10M ;如果要查询数据缓冲区大小，可以如下：SQL&gt; show parameter db。</p>
<p>在创建不同数据块表空间时，要使用参数BLOCKSIZE指出数据块的大小，同时在参数文件中要使用DB_Nk_CACHE_SIZE 进行配置，与BLOCKSIZE的个数相对应，否则会出现错误。</p>
<p>设置动态内存时，可以将多个参数全部写入参数文件，格式如下：</p><pre><ol class="dp-xml"><li class="alt"><span>#&nbsp;cache&nbsp;and&nbsp;i/o &nbsp;</span></li><li><span>&nbsp;</span><span class="attribute">DB_BLOCK_SIZE</span><span>=</span><span class="attribute-value">4096</span><span>&nbsp;</span></li><li class="alt"><span>&nbsp;</span><span class="attribute">DB_CACHE_SIZE</span><span>=</span><span class="attribute-value">20971520</span><span>&nbsp;</span></li><li><span>&nbsp;</span><span class="attribute">DB_2K_CACHE_SIZE</span><span>=</span><span class="attribute-value">8M</span><span>&nbsp;</span></li><li class="alt"><span>&nbsp;</span><span class="attribute">DB_8K_CACHE_SIZE</span><span>=</span><span class="attribute-value">4M</span><span>&nbsp;</span></li><li><span>&nbsp;&#8230;&#8230;..&nbsp;</span></li></ol></pre>
<p>其中，参数 DB_CACHE_SIZE 只适用于系统表空间、临时表空间、及默认表空间，DB_2K_CACHE_SIZE&nbsp; 适合 BLOCKSIZE 为2K的表空间。8K 也是一样的道理。</p>
<p>数据缓冲区对数据库德存取速度又直接影响。一般的缓冲区命中率应该在90% 以上。例如，使用数据字典 v$sysstat 计算数据缓冲区命中率：</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>&nbsp;select&nbsp;a.value+b.value&nbsp;&#8220;logical_reads&#8221;&nbsp;,&nbsp;c.value&nbsp;&#8220;phys_reads&#8221;, &nbsp;</span></li><li><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Round(100*&nbsp;(&nbsp;(&nbsp;a.value+b.value)-&nbsp;c.value)&nbsp;/ &nbsp;</span></li><li class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(&nbsp;a.value+b.value&nbsp;)&nbsp;)&nbsp;&#8220;buffer&nbsp;hit&nbsp;radio&nbsp;&#8220; &nbsp;</span></li><li><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;From&nbsp;v$sysstat&nbsp;a,&nbsp;v$sysstat&nbsp;b,v$sysstat&nbsp;c &nbsp;</span></li><li class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Where&nbsp;a.statistic#=38&nbsp;and&nbsp;b.statistic#=39&nbsp;and&nbsp;c.statistic#=40;&nbsp;</span></li></ol></pre>
<p>下面是计算数据缓冲命中率的另一种方法：</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>&nbsp;select&nbsp;name,&nbsp;value &nbsp;</span></li><li><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;From&nbsp;v$sysstat &nbsp;</span></li><li class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Where&nbsp;name&nbsp;in&nbsp;(&nbsp;&#8216;session&nbsp;logical&nbsp;reads&#8217;,&#8217;physical&nbsp;reads&#8217;,physical&nbsp;reads&nbsp;direct&#8217;,&nbsp;&#8216;physical&nbsp;reads&nbsp;direct&nbsp;(lob)&#8217;);&nbsp;</span></li></ol></pre>
<p>其中：Session logical reads 为读的总量。Physical reads为从数据文件读。Physical reads direct 为从缓冲区读（不含lobs）。Physical reads direct (lobs) 为从缓冲区读（含lobs）。Hit Ratio = 1- ( ( physical reads- physical reads direct &#8211; physical reads direct(lob) ) /session logical reads) = 95%。</p>
<p><strong>日志缓冲区</strong></p>
<p>日志缓冲区用来存储数据库的修改信息。日志信息首先在日志缓冲区中产生，当日志缓冲区的日志达到一定数量时，由日志写入进程LGWR将日志数据写入日志文件组，再经过切换，由归档进程ARCH将日志数据写入归档介质。</p>
<p>日志缓冲区大小由参数LOG_BUFFER确定，要查询日志缓冲区大小可以用以下方法：</p>
<p>方法一：参数文件中：</p><pre><ol class="dp-xml"><li class="alt"><span>&nbsp;&#8230;&#8230; &nbsp;</span></li><li><span>&nbsp;</span><span class="attribute">Processes</span><span>&nbsp;=&nbsp;</span><span class="attribute-value">150</span><span>&nbsp;</span></li><li class="alt"><span>&nbsp;</span><span class="attribute">Parallel_max_servers</span><span>&nbsp;=&nbsp;</span><span class="attribute-value">5</span><span>&nbsp;</span></li><li><span class="attribute">Log_buffer</span><span>&nbsp;=&nbsp;</span><span class="attribute-value">32768</span><span>&nbsp;</span></li><li class="alt"><span>&#8230;&#8230;..&nbsp;</span></li></ol></pre>
<p>方法二：</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>&nbsp;select&nbsp;name,value&nbsp;from&nbsp;v$parameter&nbsp;where&nbsp;name&nbsp;like&nbsp;&#8216;%buffer&#8217;;&nbsp;</span></li></ol></pre>
<p>方法三：</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>&nbsp;show&nbsp;parameter&nbsp;log_buffer&nbsp;</span></li></ol></pre>
<p>对于日志缓冲区而言可以计算失败率，使用数据字典v$latch 计算日志缓冲区的失败率</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>select&nbsp;name,gets,misses,immediate_gets,immediate_misses, &nbsp;</span></li><li><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Decode(gets,0,0,misses/gets*100)&nbsp;ratiol, &nbsp;</span></li><li class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Decode&nbsp;(immediate_gets+immediate_misses,0,0, &nbsp;</span></li><li><span>immediate_misses/(immediate_gets+immediate_misses)*100)&nbsp;&nbsp;&nbsp;ratio2 &nbsp;</span></li><li class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;from&nbsp;v$latch &nbsp;</span></li><li><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;where&nbsp;name&nbsp;in&nbsp;(&#8216;redo&nbsp;allocation&#8217;,&nbsp;&#8216;redo&nbsp;copy&#8217;);&nbsp;</span></li></ol></pre>
<p>其中</p>
<p>Gets 表示成功等待日志缓冲区的次数。</p>
<p>Immediate gets 表示成功立即得到日志缓冲区的次数。</p>
<p>Immediate misses 表示未成功立即得到日志缓冲区的次数。</p>
<p>等待表示日志在进入日志缓冲区时，因为日志缓冲区过小而没有空闲空间，所以日志缓冲区的失败可以表示日志缓冲区是否足够大，不够大时，用户的日志写将产生等待过程。日志缓冲区的失败率应该小于1%。</p>
<p>此外，可以查询用户进程等待日志缓冲区时的次数，通过数据字典v$sysstat 得到：</p><pre><ol class="dp-xml"><li class="alt"><span>SQL</span><span class="tag">&gt;</span><span>&nbsp;select&nbsp;name,value&nbsp;from&nbsp;v$sysstat &nbsp;</span></li><li><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Where&nbsp;</span><span class="attribute">name</span><span>&nbsp;=&nbsp;&#8216;&nbsp;redo&nbsp;buffer&nbsp;allocation&nbsp;retries&#8217;&nbsp;;&nbsp;</span></li></ol></pre>
<p>关于Oracle 10g内存结构之系统全局区的相关知识就介绍到这里了，希望本次的介绍能够对您有所收获！</p><img src ="http://www.blogjava.net/tjyhy590/aggbug/413793.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-17 23:31 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/17/413793.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle数据库命中率优化原理解析</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/16/413757.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Fri, 16 May 2014 13:14:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/16/413757.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413757.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/16/413757.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413757.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413757.html</trackback:ping><description><![CDATA[<div class="intro_p">本文是关于Oracle数据库调试与优化方面的文章，主要介绍Oracle数据库中命中率相关的问题，包括不同的算法之间性能的比对。关于Oracle中各个命中率的计算以及相关的调优 1) Library Cache的命中率: 计算公式:Library Cache Hit Ratio = sum(pinhits) / sum(pi</div>
<p>本文是关于Oracle数据库调试与优化方面的文章，主要介绍Oracle数据库中命中率相关的问题，包括不同的算法之间性能的比对。关于Oracle中各个命中率的计算以及相关的调优</p>
<p>1)<strong><span style="color: rgb(255,0,0)">Library Cache的命中率:</span></strong>计算公式:Library Cache Hit Ratio = sum(pinhits) / sum(pins)</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_778085">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql color2">SUM</code><code class="sql plain">(pinhits)/</code><code class="sql color2">sum</code><code class="sql plain">(pins) </code><code class="sql keyword">FROM</code> <code class="sql plain">V$LIBRARYCACHE;</code></div></div></td></tr></tbody></table></div></div>
<p>通常在98%以上，否则，需要要考虑加大共享池，绑定变量，修改cursor_sharing等参数。</p>
<p><br /></p>
<p>2)<strong><span style="color: rgb(255,0,0)">计算共享池内存使用率:</span></strong></p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_292147">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">(1 - ROUND(BYTES / (&amp;TSP_IN_M * 1024 * 1024), 2)) * 100 || </code><code class="sql string">'%'</code></div>
<div class="line number2 index1 alt1"><code class="sql keyword">FROM</code> <code class="sql plain">V$SGASTAT </code><code class="sql keyword">WHERE</code> <code class="sql keyword">NAME</code> <code class="sql plain">= </code><code class="sql string">'free memory'</code> <code class="sql color1">AND</code> <code class="sql plain">POOL = </code><code class="sql string">'shared pool'</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p>其中: &amp;TSP_IN_M是你的总的共享池的SIZE(M)</p>
<p>共享池内存使用率，应该稳定在75%-90%间，太小浪费内存，太大则内存不足。</p>
<p>查询空闲的共享池内存:</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_271276">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">* </code><code class="sql keyword">FROM</code> <code class="sql plain">V$SGASTAT </code><code class="sql keyword">WHERE</code></div>
<div class="line number2 index1 alt1"><code class="sql keyword">NAME</code> <code class="sql plain">= </code><code class="sql string">'free memory'</code> <code class="sql color1">AND</code> <code class="sql plain">POOL = </code><code class="sql string">'shared pool'</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p>3)<strong><span style="color: rgb(255,0,0)">db buffer cache命中率:</span></strong>计算公式:Hit ratio = 1 - [physical reads/(block gets + consistent gets)]</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_65181">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql keyword">NAME</code><code class="sql plain">, PHYSICAL_READS, DB_BLOCK_GETS, CONSISTENT_GETS, </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">1 - (PHYSICAL_READS / (DB_BLOCK_GETS + CONSISTENT_GETS))&nbsp; </code></div>
<div class="line number3 index2 alt2"><code class="sql string">"Hit Ratio"</code> <code class="sql keyword">FROM</code> <code class="sql plain">V$BUFFER_POOL_STATISTICS </code><code class="sql keyword">WHERE</code> <code class="sql keyword">NAME</code><code class="sql plain">=</code><code class="sql string">'DEFAULT'</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p>通常应在90%以上，否则，需要调整,加大DB_CACHE_SIZE</p>
<p>外一种计算命中率的方法(摘自ORACLE官方文档&lt;&lt;数据库性能优化&gt;&gt;):</p>
<p>命中率的计算公式为:</p>
<p>Hit Ratio = 1 - ((physical reads - physical reads direct - physical reads direct (lob)) / (db block gets + consistent gets - physical reads direct - physical reads direct (lob))</p>
<p>分别代入上一查询中的结果值,就得出了Buffer cache的命中率</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_608143">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql keyword">NAME</code><code class="sql plain">, VALUE </code><code class="sql keyword">FROM</code> <code class="sql plain">V$SYSSTAT </code><code class="sql keyword">WHERE</code> <code class="sql keyword">NAME</code> <code class="sql color1">IN</code><code class="sql plain">( </code></div>
<div class="line number2 index1 alt1"><code class="sql string">'session logical reads'</code><code class="sql plain">, </code><code class="sql string">'physical reads'</code><code class="sql plain">,&nbsp; </code></div>
<div class="line number3 index2 alt2"><code class="sql string">'physical reads direct'</code><code class="sql plain">, </code><code class="sql string">'physical reads direct (lob)'</code><code class="sql plain">,&nbsp; </code></div>
<div class="line number4 index3 alt1"><code class="sql string">'db block gets'</code><code class="sql plain">, </code><code class="sql string">'consistent gets'</code><code class="sql plain">);</code></div></div></td></tr></tbody></table></div></div>
<p>4)<strong><span style="color: rgb(255,0,0)">数据缓冲区命中率</span></strong>：</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_897464">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql plain">SQL&gt; </code><code class="sql keyword">select</code> <code class="sql plain">value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql plain">=</code><code class="sql string">'physical reads'</code><code class="sql plain">;&nbsp; </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">SQL&gt; </code><code class="sql keyword">select</code> <code class="sql plain">value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql plain">=</code><code class="sql string">'physical reads direct'</code><code class="sql plain">;&nbsp; </code></div>
<div class="line number3 index2 alt2"><code class="sql plain">SQL&gt; </code><code class="sql keyword">select</code> <code class="sql plain">value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql plain">=</code><code class="sql string">'physical reads direct (lob)'</code><code class="sql plain">;&nbsp; </code></div>
<div class="line number4 index3 alt1"><code class="sql plain">SQL&gt; </code><code class="sql keyword">select</code> <code class="sql plain">value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql plain">=</code><code class="sql string">'consistent gets'</code><code class="sql plain">;&nbsp; </code></div>
<div class="line number5 index4 alt2"><code class="sql plain">SQL&gt; </code><code class="sql keyword">select</code> <code class="sql plain">value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql plain">= </code><code class="sql string">'db block gets'</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p>这里命中率的计算应该是令 x = physical reads direct + physical reads direct (lob),命中率 =100 - ( physical reads - x) / (consistent gets + db block gets - x)*100,通常如果发现命中率低于90%,则应该调整应用可可以考虑是否增大数据缓冲区</p>
<p>5)<strong><span style="color: rgb(255,0,0)">共享池的命中率：</span></strong></p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_565024">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql color2">sum</code><code class="sql plain">(pinhits-reloads)/</code><code class="sql color2">sum</code><code class="sql plain">(pins)*100 </code><code class="sql string">"hit radio"</code></div>
<div class="line number2 index1 alt1"><code class="sql keyword">from</code> <code class="sql plain">v$librarycache;</code></div></div></td></tr></tbody></table></div></div>
<p>假如共享池的命中率低于95%,就要考虑调整应用(通常是没使用bind var )或者增加内存</p>
<p>6)<strong><span style="color: rgb(255,0,0)">计算在内存中排序的比率:</span></strong></p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_454995">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">* </code><code class="sql keyword">FROM</code> <code class="sql plain">v$sysstat t </code><code class="sql keyword">WHERE</code> <code class="sql keyword">NAME</code><code class="sql plain">=</code><code class="sql string">'sorts (memory)'</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p>查询内存排序数&nbsp;</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_71049">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">* </code><code class="sql keyword">FROM</code> <code class="sql plain">v$sysstat t </code><code class="sql keyword">WHERE</code> <code class="sql keyword">NAME</code><code class="sql plain">=</code><code class="sql string">'sorts (disk)'</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p>查询磁盘排序数caculate sort in memory ratio&nbsp;</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_543525">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">round(&amp;sort_in_memory/(&amp;sort_in_memory+&amp;sort_in_disk),4)*100||</code><code class="sql string">'%'</code> <code class="sql keyword">FROM</code> <code class="sql plain">dual;</code></div></div></td></tr></tbody></table></div></div>
<p>此比率越大越好,太小整要考虑调整,加大PGA</p>
<p>7)<strong><span style="color: rgb(255,0,0)">PGA的命中率:</span></strong></p>
<p>计算公式:BP x 100 / (BP + EBP)</p>
<p>BP: bytes processed</p>
<p>EBP: extra bytes read/written</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_449181">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">* </code><code class="sql keyword">FROM</code> <code class="sql plain">V$PGASTAT </code><code class="sql keyword">WHERE</code> <code class="sql keyword">NAME</code><code class="sql plain">=</code><code class="sql string">'cache hit percentage'</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p>或者从OEM的图形界面中查看<br /></p>
<p>我们可以查看一个视图以获取Oracle的建议值:</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_460412">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div>
<div class="line number6 index5 alt1">6</div>
<div class="line number7 index6 alt2">7</div>
<div class="line number8 index7 alt1">8</div>
<div class="line number9 index8 alt2">9</div>
<div class="line number10 index9 alt1">10</div>
<div class="line number11 index10 alt2">11</div>
<div class="line number12 index11 alt1">12</div>
<div class="line number13 index12 alt2">13</div>
<div class="line number14 index13 alt1">14</div>
<div class="line number15 index14 alt2">15</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">round(PGA_TARGET_FOR_ESTIMATE/1024/1024) target_mb, </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">ESTD_PGA_CACHE_HIT_PERCENTAGE cache_hit_perc, ESTD_OVERALLOC_COUNT&nbsp; </code></div>
<div class="line number3 index2 alt2"><code class="sql keyword">FROM</code> <code class="sql plain">V$PGA_TARGET_ADVICE;&nbsp; </code></div>
<div class="line number4 index3 alt1"><code class="sql plain">The </code><code class="sql keyword">output</code> <code class="sql keyword">of</code> <code class="sql plain">this query might look </code><code class="sql color1">like</code> <code class="sql plain">the following:&nbsp; </code></div>
<div class="line number5 index4 alt2"><code class="sql plain">TARGET_MB CACHE_HIT_PERC ESTD_OVERALLOC_COUNT </code></div>
<div class="line number6 index5 alt1"><code class="sql spaces">&nbsp;</code><code class="sql comments">---------- -------------- --------------------&nbsp; </code></div>
<div class="line number7 index6 alt2"><code class="sql plain">63 23 367&nbsp; </code></div>
<div class="line number8 index7 alt1"><code class="sql plain">125 24 30&nbsp; </code></div>
<div class="line number9 index8 alt2"><code class="sql plain">250 30 3&nbsp; </code></div>
<div class="line number10 index9 alt1"><code class="sql plain">375 39 0&nbsp; </code></div>
<div class="line number11 index10 alt2"><code class="sql plain">500 58 0&nbsp; </code></div>
<div class="line number12 index11 alt1"><code class="sql plain">600 59 0&nbsp; </code></div>
<div class="line number13 index12 alt2"><code class="sql plain">700 59 0&nbsp; </code></div>
<div class="line number14 index13 alt1"><code class="sql plain">800 60 0&nbsp; </code></div>
<div class="line number15 index14 alt2"><code class="sql plain">900 60 0</code></div></div></td></tr></tbody></table></div></div>
<p>在此例中:PGA至少要分配375M</p>
<p>我个人认为PGA命中率不应该低于50%</p>
<p>以下的SQL统计sql语句执行在三种模式的次数: optimal memory size, one-pass memory size, multi-pass memory size:</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_242836">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql keyword">name</code> <code class="sql plain">profile, cnt, decode(total, 0, 0, round(cnt*100/total,4))&nbsp; </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">percentage </code><code class="sql keyword">FROM</code> <code class="sql plain">(</code><code class="sql keyword">SELECT</code> <code class="sql keyword">name</code><code class="sql plain">, value cnt, (</code><code class="sql color2">sum</code><code class="sql plain">(value) over ())&nbsp; </code></div>
<div class="line number3 index2 alt2"><code class="sql plain">total </code><code class="sql keyword">FROM</code> <code class="sql plain">V$SYSSTAT </code><code class="sql keyword">WHERE</code> <code class="sql keyword">name</code> <code class="sql color1">like</code> <code class="sql string">'workarea exec%'</code><code class="sql plain">);</code></div></div></td></tr></tbody></table></div></div>
<p>8)<strong><span style="color: rgb(255,0,0)">共享区字典缓存区命中率</span></strong><br /></p>
<p>计算公式：SUM(gets - getmisses - usage -fixed) / SUM(gets)</p>
<p>命中率应大于0.85</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_151336">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql color2">sum</code><code class="sql plain">(gets-getmisses-usage-fixed)/</code><code class="sql color2">sum</code><code class="sql plain">(gets) </code><code class="sql keyword">from</code> <code class="sql plain">v$rowcache;</code></div></div></td></tr></tbody></table></div></div>
<p>9)<strong><span style="color: rgb(255,0,0)">数据高速缓存区命中率</span></strong></p>
<p>计算公式：1-(physical reads / (db block gets + consistent gets))<br /></p>
<p>命中率应大于0.90最好</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_2426">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql keyword">name</code><code class="sql plain">,value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql color1">in</code> <code class="sql plain">(</code><code class="sql string">'physical reads'</code><code class="sql plain">,</code><code class="sql string">'db block gets'</code><code class="sql plain">,</code><code class="sql string">'consistent gets'</code><code class="sql plain">);</code></div></div></td></tr></tbody></table></div></div>
<p>10)<strong><span style="color: rgb(255,0,0)">共享区库缓存区命中率</span></strong></p>
<p>计算公式：SUM(pins - reloads) / SUM(pins)</p>
<p>命中率应大于0.99</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_255745">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql color2">sum</code><code class="sql plain">(pins-reloads)/</code><code class="sql color2">sum</code><code class="sql plain">(pins) </code><code class="sql keyword">from</code> <code class="sql plain">v$librarycache;</code></div></div></td></tr></tbody></table></div></div>
<p>11)<strong><span style="color: rgb(255,0,0)">检测回滚段的争用</span></strong></p>
<p>SUM(waits)值应小于SUM(gets)值的1%</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_987364">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql color2">sum</code><code class="sql plain">(gets),</code><code class="sql color2">sum</code><code class="sql plain">(waits),</code><code class="sql color2">sum</code><code class="sql plain">(waits)/</code><code class="sql color2">sum</code><code class="sql plain">(gets) </code><code class="sql keyword">from</code> <code class="sql plain">v$rollstat;</code></div></div></td></tr></tbody></table></div></div>
<p>12)<strong><span style="color: rgb(255,0,0)">检测回滚段收缩次数</span></strong></p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_93094">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql keyword">name</code><code class="sql plain">,shrinks </code><code class="sql keyword">from</code> <code class="sql plain">v$rollstat, v$rollname&nbsp; </code></div>
<div class="line number2 index1 alt1"><code class="sql keyword">where</code> <code class="sql plain">v$rollstat.usn = v$rollname.usn;</code></div></div></td></tr></tbody></table></div></div>
<p>&nbsp;</p>
<p><strong><span style="color: rgb(255,0,0)">几个常用的检查语句</span></strong></p>
<p>1. 查找排序最多的SQL:</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_44746">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">HASH_VALUE, SQL_TEXT, SORTS, EXECUTIONS&nbsp; </code></div>
<div class="line number2 index1 alt1"><code class="sql keyword">FROM</code> <code class="sql plain">V$SQLAREA </code><code class="sql keyword">ORDER</code> <code class="sql keyword">BY</code> <code class="sql plain">SORTS </code><code class="sql keyword">DESC</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p><br /></p>
<p>2.查找磁盘读写最多的SQL:</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_206165">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">* </code><code class="sql keyword">FROM</code> <code class="sql plain">(</code><code class="sql keyword">SELECT</code> <code class="sql plain">sql_text,disk_reads </code><code class="sql string">"total disk"</code> <code class="sql plain">,&nbsp; </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">executions </code><code class="sql string">"total exec"</code><code class="sql plain">,disk_reads/executions </code><code class="sql string">"disk/exec"</code></div>
<div class="line number3 index2 alt2"><code class="sql keyword">FROM</code> <code class="sql plain">v$sql </code><code class="sql keyword">WHERE</code> <code class="sql plain">executions&gt;0 </code><code class="sql color1">and</code> <code class="sql plain">is_obsolete=</code><code class="sql string">'N'</code> <code class="sql keyword">ORDER</code> <code class="sql keyword">BY</code></div>
<div class="line number4 index3 alt1"><code class="sql plain">4 </code><code class="sql keyword">desc</code><code class="sql plain">) </code><code class="sql keyword">WHERE</code> <code class="sql plain">ROWNUM&lt;11 ;</code></div></div></td></tr></tbody></table></div></div>
<p><br /></p>
<p>3.查找工作量最大的SQL(实际上也是按磁盘读写来排序的):</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_593686">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div>
<div class="line number6 index5 alt1">6</div>
<div class="line number7 index6 alt2">7</div>
<div class="line number8 index7 alt1">8</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql plain">substr(to_char(s.pct, </code><code class="sql string">'99.00'</code><code class="sql plain">), 2) || </code><code class="sql string">'%'</code> <code class="sql keyword">load</code><code class="sql plain">, </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">s.executions executes,p.sql_text </code><code class="sql keyword">from</code><code class="sql plain">(</code><code class="sql keyword">select</code> <code class="sql plain">address,disk_reads,executions,pct,rank() over&nbsp; </code></div>
<div class="line number3 index2 alt2"><code class="sql plain">(</code><code class="sql keyword">order</code> <code class="sql keyword">by</code> <code class="sql plain">disk_reads </code><code class="sql keyword">desc</code><code class="sql plain">) ranking </code><code class="sql keyword">from</code> <code class="sql plain">(</code><code class="sql keyword">select</code></div>
<div class="line number4 index3 alt1"><code class="sql plain">address,disk_reads,executions,100 * ratio_to_report </code></div>
<div class="line number5 index4 alt2"><code class="sql plain">(disk_reads) over () pct </code><code class="sql keyword">from</code> <code class="sql plain">sys.v_$sql </code><code class="sql keyword">where</code></div>
<div class="line number6 index5 alt1"><code class="sql plain">command_type != 47) </code><code class="sql keyword">where</code> <code class="sql plain">disk_reads &gt; 50 * executions) s, </code></div>
<div class="line number7 index6 alt2"><code class="sql plain">ys.v_$sqltext p </code><code class="sql keyword">where</code> <code class="sql plain">s.ranking &lt;= 5 </code><code class="sql color1">and</code> <code class="sql plain">p.address = s.address&nbsp; </code></div>
<div class="line number8 index7 alt1"><code class="sql keyword">order</code> <code class="sql keyword">by</code> <code class="sql plain">1, s.address, p.piece;</code></div></div></td></tr></tbody></table></div></div>
<p>　　</p>
<p>4. 用下列SQL工具找出低效SQL:</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_696017">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql plain">executions,disk_reads,buffer_gets,round((buffer_gets- </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">disk_reads)/buffer_gets,2) Hit_radio,round(disk_reads/executions,2) </code></div>
<div class="line number3 index2 alt2"><code class="sql plain">reads_per_run,sql_text </code><code class="sql keyword">From</code> <code class="sql plain">v$sqlarea </code><code class="sql keyword">Where</code> <code class="sql plain">executions&gt;0 </code><code class="sql color1">and</code></div>
<div class="line number4 index3 alt1"><code class="sql plain">buffer_gets &gt;0 </code><code class="sql color1">and</code> <code class="sql plain">(buffer_gets-disk_reads)/buffer_gets&lt;0.8&nbsp; </code></div>
<div class="line number5 index4 alt2"><code class="sql keyword">Order</code> <code class="sql keyword">by</code> <code class="sql plain">4 </code><code class="sql keyword">desc</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p>　　</p>
<p>5、根据sid查看对应连接正在运行的sql</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_265009">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div>
<div class="line number6 index5 alt1">6</div>
<div class="line number7 index6 alt2">7</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql plain">/*+ push_subq */command_type,sql_text,sharable_mem,persistent_mem, </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">runtime_mem,sorts,version_count,loaded_versions,open_versions, </code></div>
<div class="line number3 index2 alt2"><code class="sql plain">users_opening,executions,users_executing,loads,first_load_time, </code></div>
<div class="line number4 index3 alt1"><code class="sql plain">invalidations,parse_calls,disk_reads,buffer_gets,rows_processed, </code></div>
<div class="line number5 index4 alt2"><code class="sql plain">sysdate start_time,sysdate finish_time,&#8217;&gt;&#8217;||address&nbsp; </code></div>
<div class="line number6 index5 alt1"><code class="sql plain">sql_address,&#8217;N&#8217;status </code><code class="sql keyword">From</code> <code class="sql plain">v$sqlarea </code><code class="sql keyword">Where</code> <code class="sql plain">address= </code></div>
<div class="line number7 index6 alt2"><code class="sql plain">(</code><code class="sql keyword">select</code> <code class="sql plain">sql_address </code><code class="sql keyword">from</code> <code class="sql plain">v$session </code><code class="sql keyword">where</code> <code class="sql plain">sid=&amp;sid);</code></div></div></td></tr></tbody></table></div></div>
<p><br /></p>
<p>***************Oracle 缓冲区命中率低的分析及解决办法******************</p>
<p>首先确定下面的查询结果:</p>
<p>1,缓冲区命中率的查询(是否低于90%):</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_791497">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql plain">round((1 - </code><code class="sql color2">sum</code><code class="sql plain">(decode(</code><code class="sql keyword">name</code><code class="sql plain">,</code><code class="sql string">'physical reads'</code><code class="sql plain">,value,0)) /&nbsp; </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">(</code><code class="sql color2">sum</code><code class="sql plain">(decode(</code><code class="sql keyword">name</code><code class="sql plain">,</code><code class="sql string">'db block gets'</code><code class="sql plain">,value,0)) + </code><code class="sql color2">sum</code><code class="sql plain">(decode(</code><code class="sql keyword">name</code><code class="sql plain">,</code><code class="sql string">' </code></div>
<div class="line number3 index2 alt2"><code class="sql string">consistent gets'</code><code class="sql plain">,value,0))) ),4) *100 || </code><code class="sql string">'%'</code> <code class="sql plain">chitrati </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat;</code></div></div></td></tr></tbody></table></div></div>
<p>　　</p>
<p>2,使用率的查询(有无free状态的数据快.):</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_113593">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql color2">count</code><code class="sql plain">(*), status </code><code class="sql keyword">from</code> <code class="sql plain">v$bh </code><code class="sql keyword">group</code> <code class="sql keyword">by</code> <code class="sql plain">status ;</code></div></div></td></tr></tbody></table></div></div>
<p>　　</p>
<p>3,相关等待事件的查询(是否有相关等待事件)</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_759044">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql plain">event,total_waits </code><code class="sql keyword">from</code> <code class="sql plain">v$system_event </code><code class="sql keyword">where</code> <code class="sql plain">event&nbsp; </code></div>
<div class="line number2 index1 alt1"><code class="sql color1">in</code> <code class="sql plain">(</code><code class="sql string">'free buffer waits'</code><code class="sql plain">);</code></div></div></td></tr></tbody></table></div></div>
<p>　　</p>
<p>4,当前大小(是否已经很大)</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_682229">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql plain">value/1024/1024 cache_size </code><code class="sql keyword">from</code> <code class="sql plain">v$parameter&nbsp; </code></div>
<div class="line number2 index1 alt1"><code class="sql keyword">where</code> <code class="sql keyword">name</code><code class="sql plain">=</code><code class="sql string">'db_cache_size'</code></div></div></td></tr></tbody></table></div></div>
<p><br /></p>
<p>5,top等待事件分析(Db file scatered read的比率是否大)</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_818111">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div>
<div class="line number6 index5 alt1">6</div>
<div class="line number7 index6 alt2">7</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql plain">event ,total_waits,suml </code><code class="sql keyword">from</code> <code class="sql plain">(</code><code class="sql keyword">select</code></div>
<div class="line number2 index1 alt1"><code class="sql plain">event,total_waits,round(total_waits/sumt*100,2)||</code><code class="sql string">'%'</code> <code class="sql plain">suml&nbsp; </code></div>
<div class="line number3 index2 alt2"><code class="sql keyword">from</code> <code class="sql plain">(</code><code class="sql keyword">select</code> <code class="sql plain">event,total_waits </code><code class="sql keyword">from</code> <code class="sql plain">v$system_event ),&nbsp; </code></div>
<div class="line number4 index3 alt1"><code class="sql plain">(</code><code class="sql keyword">select</code> <code class="sql color2">sum</code><code class="sql plain">(total_waits) sumt </code><code class="sql keyword">from</code> <code class="sql plain">v$system_event)&nbsp; </code></div>
<div class="line number5 index4 alt2"><code class="sql keyword">order</code> <code class="sql keyword">by</code> <code class="sql plain">total_waits </code><code class="sql keyword">desc</code><code class="sql plain">) </code><code class="sql keyword">where</code> <code class="sql plain">rownum&lt;6 </code><code class="sql color1">and</code> <code class="sql plain">event&nbsp; </code></div>
<div class="line number6 index5 alt1"><code class="sql color1">not</code> <code class="sql color1">like</code> <code class="sql string">'rdbms%'</code> <code class="sql color1">and</code> <code class="sql plain">event </code><code class="sql color1">not</code> <code class="sql color1">like</code> <code class="sql string">'pmon%'</code> <code class="sql color1">and</code> <code class="sql plain">event&nbsp; </code></div>
<div class="line number7 index6 alt2"><code class="sql color1">not</code> <code class="sql color1">like</code> <code class="sql string">'SQL*Net%'</code> <code class="sql color1">and</code> <code class="sql plain">event </code><code class="sql color1">not</code> <code class="sql color1">like</code> <code class="sql string">'smon%'</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p>　　</p>
<p>6,db_cache_advice建议值(9i后的新特性,可以根据他更好的调整cache_size)</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_501568">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql plain">block_size,size_for_estimate,size_factor, </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">estd_physical_reads </code><code class="sql keyword">from</code> <code class="sql plain">v$db_cache_advice;</code></div></div></td></tr></tbody></table></div></div>
<p><br /></p>
<p>说明分析:</p>
<p>缓冲区命中率(低于90的命中率就算比较低的).</p>
<p>没有free不一定说明需要增加,还要结合当前cache_size的大小(我们是否还可以再增大,是否有需要增加硬件,增加开销),</p>
<p>空闲缓冲区等待说明进程找不到空闲缓冲区，并通过写出灰缓冲区，来加速数据库写入器生成空闲缓冲区，当DBWn将块写入磁盘后，灰数据缓冲区将被释放，以便重新使用.产生这种原因主要是:</p>
<p>1，DBWn可能跟不上写入灰缓冲区：i/0系统较慢，尽量将文件均匀的分布于所有设备，</p>
<p>2，缓冲区过小或过大。</p>
<p>3，可以增加db_writer_processes数量。</p>
<p>4,可能有很大的一个事物，或者连续的大事物</p>
<p>我们需要长期观察这个事件是否长期存在并数值一直在增大,如果一直在增大,则说明需要增大db_cache大小.或优化sql.</p>
<p>数据分散读等待,通常表现存在着与全表扫描相关的等待，逻辑读时，在内存中进行的全表扫描一般是零散地，而并非连续的被分散到缓冲区的各个部分，可能有索引丢失，或被仰制索引的存在。该等待时间在数据库会话等待多块io读取结束的时候产生，并把指定的块数离散的分布在数据缓冲区。这意味这全表扫描过多，或者io不足或争用，</p>
<p>存在这个事件,多数都是问题的,这说明大量的全部扫描而未采用索引.</p>
<p>db_cache_advice对我们调整db_cache_size大小有一定的帮助,但这只是一个参考，不一定很精确。</p>
<p>通过上面6种情况的综合分析,判断是否需要增加大cache_size. 或者把常用的(小)表放到keep区。</p>
<p>但多数的时候做这些不会解决质的问题,</p>
<p>而真正的问题主要是对sql语句的优化(如:是否存在大量的全表扫描等)</p>
<p>索引是在不需要改变程序的情况下,对数据库性能，sql语句提高的最实用的方法.</p>
<p>我在生产中遇到过类似的问题,200M的cache_size,命中率很低21%,但通过对sql语句的优化(添加索引,避免全表扫描),命中率增加到96%,程序运行时间由原来的2小时减少到不到10分钟.</p>
<p>这就提到了怎么定位高消耗的sql问题.全表扫描的问题,在这里不做细致的解说,这里只说明方法,我会在相关的章节专门介绍怎么使用这些工具</p>
<p>1,sql_trace跟踪session.用tkprof 分别输出磁盘读,逻辑读,运行时间长的sql进行优化.这些高消耗的sql一般都伴随着全表扫描.</p>
<p>2,statspack分析.在系统繁忙时期进行时间点的统计分析,产看TOP事件是否有Db file scatered read.并查看TOP sql语句是否存在问题等.</p>
<p>还要说一句：当然在硬件允许的情况下，尽量增大db_cache_size 减少磁盘读，但并不是越大越好，一定要根据自己的库数据量的程度来调节，因为大的db_cache_size同样会增大数据库管理的开销，当然可能开销并不会明显的影响数据库的性能，硬件价格也越来越低，这就需要我们具体问题具体分析了，在我看来物尽其用就最好了，尽量不要浪费，找到问题的本质。调优是一件很艺术的事。</p>
<p>***********************Oracle数据库缓冲区命中率*****************</p>
<p>1、查看Oracle数据库缓冲区命中率</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_454409">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql plain">a.value + b.value </code><code class="sql string">"logical_reads"</code><code class="sql plain">, c.value </code><code class="sql string">"phys_reads"</code><code class="sql plain">,&nbsp; </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">round(100 * ((a.value+b.value)-c.value) / (a.value+b.value))&nbsp; </code></div>
<div class="line number3 index2 alt2"><code class="sql string">"BUFFER HIT RATIO"</code> <code class="sql keyword">from</code> <code class="sql plain">v$sysstat a, v$sysstat b, v$sysstat c&nbsp; </code></div>
<div class="line number4 index3 alt1"><code class="sql keyword">where</code> <code class="sql plain">a.statistic# = 40 </code><code class="sql color1">and</code> <code class="sql plain">b.statistic# = 41 </code><code class="sql color1">and</code> <code class="sql plain">c.statistic# = 42;</code></div></div></td></tr></tbody></table></div></div>
<p><br /></p>
<p>2、Tags: oracle</p>
<p>数据库缓冲区命中率：</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_763923">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div>
<div class="line number6 index5 alt1">6</div>
<div class="line number7 index6 alt2">7</div>
<div class="line number8 index7 alt1">8</div>
<div class="line number9 index8 alt2">9</div>
<div class="line number10 index9 alt1">10</div>
<div class="line number11 index10 alt2">11</div>
<div class="line number12 index11 alt1">12</div>
<div class="line number13 index12 alt2">13</div>
<div class="line number14 index13 alt1">14</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql plain">value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql plain">=</code><code class="sql string">'physical reads'</code><code class="sql plain">;&nbsp; </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">value 3714179&nbsp; </code></div>
<div class="line number3 index2 alt2"><code class="sql spaces">&nbsp;&nbsp;</code>&nbsp;</div>
<div class="line number4 index3 alt1"><code class="sql keyword">select</code> <code class="sql plain">value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql plain">=</code><code class="sql string">'physical reads direct'</code><code class="sql plain">;&nbsp; </code></div>
<div class="line number5 index4 alt2"><code class="sql plain">value 0&nbsp; </code></div>
<div class="line number6 index5 alt1"><code class="sql spaces">&nbsp;&nbsp;</code>&nbsp;</div>
<div class="line number7 index6 alt2"><code class="sql keyword">select</code> <code class="sql plain">value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql plain">=</code><code class="sql string">'physical reads direct(lob)'</code><code class="sql plain">; </code></div>
<div class="line number8 index7 alt1"><code class="sql plain">value 0&nbsp; </code></div>
<div class="line number9 index8 alt2"><code class="sql spaces">&nbsp;&nbsp;</code>&nbsp;</div>
<div class="line number10 index9 alt1"><code class="sql keyword">select</code> <code class="sql plain">value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql plain">=</code><code class="sql string">'consistent gets'</code><code class="sql plain">;&nbsp; </code></div>
<div class="line number11 index10 alt2"><code class="sql plain">value 856309623&nbsp; </code></div>
<div class="line number12 index11 alt1"><code class="sql spaces">&nbsp;&nbsp;</code>&nbsp;</div>
<div class="line number13 index12 alt2"><code class="sql keyword">select</code> <code class="sql plain">value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql plain">=</code><code class="sql string">'db block gets'</code><code class="sql plain">;&nbsp; </code></div>
<div class="line number14 index13 alt1"><code class="sql plain">value 19847790</code></div></div></td></tr></tbody></table></div></div>
<p>这里命中率的计算应该是</p>
<p>令x=physical reads direct + physical reads direct(lob)</p>
<p>命中率=100-(physical reads -x)/(consistent gets +db block gets -x)*100</p>
<p>通常如果发现命中率低于90%，则应该调整应用可以考虑是否增大数据加</p>
<p><br /></p>
<p>共享池的命中率</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_766006">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql color2">sum</code><code class="sql plain">(pinhits)/</code><code class="sql color2">sum</code><code class="sql plain">(pins)*100 </code><code class="sql string">"hit radio"</code> <code class="sql keyword">from</code> <code class="sql plain">v$librarycache;</code></div></div></td></tr></tbody></table></div></div>
<p>如果共享池的命中率低于95%就要考虑调整应用(通常是没应用bind var)或者增加内存。</p>
<p>关于排序部分</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_15782">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql keyword">name</code><code class="sql plain">,value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code> <code class="sql color1">like</code> <code class="sql string">'%sort%'</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p>如果我们发现sorts(disk)/(sorts(memory)+sorts(disk))的比例过高，则通常意味着sort_area_size部分内存教较小，可考虑调整相应的参数。</p>
<p>　　</p>
<p>关于log_buffer</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_912805">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql keyword">name</code><code class="sql plain">,value </code><code class="sql keyword">from</code> <code class="sql plain">v$sysstat </code><code class="sql keyword">where</code> <code class="sql keyword">name</code></div>
<div class="line number2 index1 alt1"><code class="sql color1">in</code> <code class="sql plain">(</code><code class="sql string">'redo entries'</code><code class="sql plain">,</code><code class="sql string">'redo buffer allocation retries'</code><code class="sql plain">);</code></div></div></td></tr></tbody></table></div></div>
<p>假如redo buffer allocation retries/redo entries的比例超过1%我们就可以考虑增加log_buffer.</p><img src ="http://www.blogjava.net/tjyhy590/aggbug/413757.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-16 21:14 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/16/413757.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>深入理解Oracle Statistic统计信息</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/16/413754.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Fri, 16 May 2014 11:08:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/16/413754.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413754.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/16/413754.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413754.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413754.html</trackback:ping><description><![CDATA[<div class="intro_p">1.统计信息简介 统计信息主要是描述数据库中表，索引的大小，规模，数据分布状况等的一类信息。比如，表的行数，块数，平均每行的大小，索引的leaf blocks，索引字段的行数，不同值的大小等，都属于统计信息。CBO正是根据这些统计信息数据，计算出不同访问路</div>
<h4><span style="color: rgb(255,0,0)">1.统计信息简介</span></h4>
<p>统计信息主要是描述数据库中表，索引的大小，规模，数据分布状况等的一类信息。比如，表的行数，块数，平均每行的大小，索引的leaf blocks，索引字段的行数，不同值的大小等，都属于统计信息。CBO正是根据这些统计信息数据，计算出不同访问路径下，不同join&nbsp;方式下，各种计划的成本，最后选择出成本最小的计划。</p>
<p>在CBO(基于代价的优化器模式)条件下，SQL语句的执行计划由统计信息来决定，若没有统计信息则会采取动态采样的方式决定执行计划！可以说统计信息关乎sql的执行计划是否正确，属于sql执行的指导思想，oracle的初始化参数statistics_level控制收集统计信息的级别，有三个参数值:</p>
<p>BASIC :收集基本的统计信息</p>
<p>TYPICAL：收集大部分统计信息(数据库的默认设置)</p>
<p>ALL：收集全部统计信息</p>
<p>Oracle 10g之后，Query Optimizer就已经将CBO作为默认优化器，并且Oracle官方不再支持RBO服务。但是，通过优化器参数optimizer_mode，我们可以控制Oracle优化器生成不同模式下的执行计划。</p>
<p sizset="43" sizcache08185750588433172="14">关于优化器的请参考：《<a title="SQL性能优化之optimizer_mode参数原理渗透解析" href="http://www.askoracle.org/oracle/performance/624.html" target="_blank">SQL性能优化之optimizer_mode参数原理渗透解析</a>》</p>
<h4><span style="color: rgb(255,0,0)">2.如何收集统计信息</span></h4>
<h5><span style="color: rgb(255,0,0)">2.1&nbsp;统计信息的内容：</span></h5>
<p>1）Table statistics</p>
<p>Number of rows --行数量</p>
<p>Number of blocks --block数量</p>
<p>Average row length --平均行的长度.</p>
<p>2）Column statistics</p>
<p>Number of distinct values (NDV) in column --列中distinct的值</p>
<p>Number of nulls in column --列中null的值</p>
<p>Data distribution (histogram)&nbsp; --数据分布</p>
<p>3）Index statistics</p>
<p>Number of leaf blocks --子节点的块数量</p>
<p>Levels --子节点数量</p>
<p>Clustering factor --集群因子</p>
<p>4）System statistics</p>
<p>I/O performance and utilization --IO性能和利用率</p>
<p>CPU performance and utilization --CPU的性能和利用率</p>
<h5><span style="color: rgb(255,0,0)">2.2&nbsp;收集统计信息</span></h5>
<p>Oracle Statistic&nbsp;的收集，可以使用analyze&nbsp;命令，也可以使用DBMS_STATS&nbsp;包来收集，Oracle&nbsp;建议使用DBMS_STATS包来收集统计信息，因为DBMS_STATS包收集的更广，并且更准确。analyze&nbsp;在以后的版本中可能会被移除。</p>
<p>DBMS_STATS常用的几个过程如下：</p>
<div>
<div class="syntaxhighlighter  xml ie" id="highlighter_285272">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div>
<div class="line number6 index5 alt1">6</div>
<div class="line number7 index6 alt2">7</div>
<div class="line number8 index7 alt1">8</div>
<div class="line number9 index8 alt2">9</div>
<div class="line number10 index9 alt1">10</div>
<div class="line number11 index10 alt2">11</div>
<div class="line number12 index11 alt1">12</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="xml plain">dbms_stats.gather_table_stats 收集表、列和索引的统计信息； </code></div>
<div class="line number2 index1 alt1"><code class="xml plain">dbms_stats.gather_schema_stats 收集SCHEMA下所有对象的统计信息； </code></div>
<div class="line number3 index2 alt2"><code class="xml plain">dbms_stats.gather_index_stats 收集索引的统计信息； </code></div>
<div class="line number4 index3 alt1"><code class="xml plain">dbms_stats.gather_system_stats 收集系统统计信息 </code></div>
<div class="line number5 index4 alt2"><code class="xml plain">dbms_stats.GATHER_DICTIONARY_STATS：所有字典对象的统计； </code></div>
<div class="line number6 index5 alt1"><code class="xml plain">DBMS_STATS.GATHER_DICTIONARY_STATS 其收集所有系统模式的统计 </code></div>
<div class="line number7 index6 alt2"><code class="xml plain">dbms_stats.delete_table_stats 删除表的统计信息 </code></div>
<div class="line number8 index7 alt1"><code class="xml plain">dbms_stats.delete_index_stats 删除索引的统计信息 </code></div>
<div class="line number9 index8 alt2"><code class="xml plain">dbms_stats.export_table_stats 输出表的统计信息 </code></div>
<div class="line number10 index9 alt1"><code class="xml plain">dbms_stats.create_state_table </code></div>
<div class="line number11 index10 alt2"><code class="xml plain">dbms_stats.set_table_stats 设置表的统计 </code></div>
<div class="line number12 index11 alt1"><code class="xml plain">dbms_stats.auto_sample_size</code></div></div></td></tr></tbody></table></div></div>
<p>analyze&nbsp;命令的语法如下：</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_542853">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql plain">SQL&gt;analyze </code><code class="sql keyword">table</code> <code class="sql plain">tablename compute </code><code class="sql keyword">statistics</code><code class="sql plain">; </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">SQL&gt;analyze </code><code class="sql keyword">table</code> <code class="sql plain">tablename compute </code><code class="sql keyword">statistics</code> <code class="sql keyword">for</code> <code class="sql color1">all</code> <code class="sql plain">indexes; </code></div>
<div class="line number3 index2 alt2"><code class="sql plain">SQL&gt;analyze </code><code class="sql keyword">table</code> <code class="sql plain">tablename </code><code class="sql keyword">delete</code> <code class="sql keyword">statistics</code></div></div></td></tr></tbody></table></div></div>
<h5><span style="color: rgb(255,0,0)">2.3&nbsp;统计信息的分类</span></h5>
<p>Oracle&nbsp;的Statistic 信息的收集分两种：自动收集和手工收集。</p>
<p>Oracle&nbsp;的Automatic Statistics Gathering&nbsp;是通过Scheduler&nbsp;来实现收集和维护的。Job&nbsp;名称是GATHER_STATS_JOB,&nbsp;该Job收集数据库所有对象的2种统计信息：</p>
<p>（1）Missing statistics（统计信息缺失）</p>
<p>（2）Stale statistics（统计信息陈旧）</p>
<p>该Job&nbsp;是在数据库创建的时候自动创建，并由Scheduler来管理。Scheduler 在maintenance windows open时运行gather job。&nbsp;默认情况下，job&nbsp;会在每天晚上10到早上6点和周末全天开启。该过程首先检测统计信息缺失和陈旧的对象。然后确定优先级，再开始进行统计信息。</p>
<p>Scheduler Job的stop_on_window_close&nbsp;属性控制GATHER_STATS_JOB&nbsp;是否继续。该属性默认值为True.&nbsp;如果该值设置为False，那么GATHER_STATS_JOB 会中断，&nbsp;而没有收集完的对象将在下次启动时继续收集。</p>
<p>Gather_stats_job&nbsp;调用dbms_stats.gather_database_stats_job_proc过程来收集statistics 的信息。&nbsp;该过程收集对象statistics的条件如下：</p>
<p>（1）对象的统计信息之前没有收集过。</p>
<p>（2）当对象有超过10%的rows&nbsp;被修改，此时对象的统计信息也称为stale statistics。</p>
<p>但是对于高度变化的表在白天的活动期间被TRUNCATE/DROP并重建或者块加载超过本身总大小10%的对象；我们可以将这些表上的统计设置为NULL</p>
<p>可以通过以下SQL来查看：</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_975376">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">select</code> <code class="sql plain">job_name, program_name, enabled, stop_on_window_close </code></div>
<div class="line number2 index1 alt1"><code class="sql spaces">&nbsp;&nbsp;</code><code class="sql keyword">from</code> <code class="sql plain">dba_scheduler_jobs </code></div>
<div class="line number3 index2 alt2"><code class="sql spaces">&nbsp;</code><code class="sql keyword">where</code> <code class="sql plain">job_name = </code><code class="sql string">'gather_stats_job'</code><code class="sql plain">;</code></div></div></td></tr></tbody></table></div></div>
<p>为了决定是否对对象进行监控，Oracle 提供了一个参数STATISTICS_LEVEL。通过设置初始化参数STATISTIC_LEVEL&nbsp;为TYPICAL&nbsp;或ALL，就可以自动收集统计信息(默认值为TYPICAL，因此可以随即启用自动收集统计信息的功能)。STATISTIC_LEVEL&nbsp;参数的值可以激活GATHER_STATS_JOB。</p>
<p>在10g中表监控默认是激活的，如果STATISTICS_LEVEL设置为basic，不仅不能监控表，而且将禁掉如下一些10g的新功能：</p>
<p>（1）ASH(Active Session History)</p>
<p>（2）ASSM(Automatic Shared Memory Management)</p>
<p>（3）AWR(Automatic Workload Repository)</p>
<p>（4）ADDM(Automatic Database Diagnostic Monitor)</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_257507">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql plain">sys@ORCL&gt; show parameter statistics_level; </code></div>
<div class="line number2 index1 alt1"><code class="sql spaces">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</code>&nbsp;</div>
<div class="line number3 index2 alt2"><code class="sql keyword">NAME</code>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <code class="sql plain">TYPE&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; VALUE </code></div>
<div class="line number4 index3 alt1"><code class="sql comments">------------------------------------ ----------- --------- </code></div>
<div class="line number5 index4 alt2"><code class="sql plain">statistics_level&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; string&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TYPICAL</code></div></div></td></tr></tbody></table></div></div>
<p>当启动对象的监控后，从上次统计信息收集之后的的信息，如inserts，updates，deletes 等，这些改变的信息会记录到user_tab_modifications&nbsp;视图。</p>
<p>当对象的数据发生改变之后，&nbsp;经过几分钟的延时，这些信息写入到user_tab_modifications视图，然后dbms_stats.flush_database_monitoring_info过程就会发现这些信息，并讲这些信息保存在内存中。</p>
<p>当监控的对象被修改的部分超过10%时，gather_database_stats&nbsp;或者gather_schema_stats&nbsp;过程就会去收集这些stale statistics</p>
<h4><span style="color: rgb(255,0,0)">3.统计信息的存储位置以及常用数据字典</span></h4>
<h5><span style="color: rgb(255,0,0)">3.1&nbsp;统计信息常用数据字典</span></h5>
<p>统计信息收集如下数据：</p>
<p>（1）表自身的分析：&nbsp;包括表中的行数，数据块数，行长等信息。</p>
<p>（2）列的分析：包括列值的重复数，列上的空值，数据在列上的分布情况。</p>
<p>（3）索引的分析：&nbsp;包括索引叶块的数量，索引的深度，索引的聚合因子等。</p>
<p>这些统计信息存放在以下的数据字典里：</p>
<div>
<div class="syntaxhighlighter  xml ie" id="highlighter_360175">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div>
<div class="line number6 index5 alt1">6</div>
<div class="line number7 index6 alt2">7</div>
<div class="line number8 index7 alt1">8</div>
<div class="line number9 index8 alt2">9</div>
<div class="line number10 index9 alt1">10</div>
<div class="line number11 index10 alt2">11</div>
<div class="line number12 index11 alt1">12</div>
<div class="line number13 index12 alt2">13</div>
<div class="line number14 index13 alt1">14</div>
<div class="line number15 index14 alt2">15</div>
<div class="line number16 index15 alt1">16</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="xml plain">DBA_TABLES </code></div>
<div class="line number2 index1 alt1"><code class="xml plain">DBA_OBJECT_TABLES </code></div>
<div class="line number3 index2 alt2"><code class="xml plain">DBA_TAB_STATISTICS </code></div>
<div class="line number4 index3 alt1"><code class="xml plain">DBA_TAB_COL_STATISTICS </code></div>
<div class="line number5 index4 alt2"><code class="xml plain">DBA_TAB_HISTOGRAMS </code></div>
<div class="line number6 index5 alt1"><code class="xml plain">DBA_INDEXES </code></div>
<div class="line number7 index6 alt2"><code class="xml plain">DBA_IND_STATISTICS </code></div>
<div class="line number8 index7 alt1"><code class="xml plain">DBA_CLUSTERS </code></div>
<div class="line number9 index8 alt2"><code class="xml plain">DBA_TAB_PARTITIONS </code></div>
<div class="line number10 index9 alt1"><code class="xml plain">DBA_TAB_SUBPARTITIONS </code></div>
<div class="line number11 index10 alt2"><code class="xml plain">DBA_IND_PARTITIONS </code></div>
<div class="line number12 index11 alt1"><code class="xml plain">DBA_IND_SUBPARTITIONS </code></div>
<div class="line number13 index12 alt2"><code class="xml plain">DBA_PART_COL_STATISTICS </code></div>
<div class="line number14 index13 alt1"><code class="xml plain">DBA_PART_HISTOGRAMS </code></div>
<div class="line number15 index14 alt2"><code class="xml plain">DBA_SUBPART_COL_STATISTICS </code></div>
<div class="line number16 index15 alt1"><code class="xml plain">DBA_SUBPART_HISTOGRAMS</code></div></div></td></tr></tbody></table></div></div>
<h5><span style="color: rgb(255,0,0)">3.2&nbsp;表的统计信息</span></h5>
<p>包含表行数，使用的块数，空的块数，块的使用率，行迁移和链接的数量，pctfree，pctused的数据，行的平均大小：</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_572159">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div>
<div class="line number6 index5 alt1">6</div>
<div class="line number7 index6 alt2">7</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">NUM_ROWS, </code><code class="sql comments">--表中的记录数 </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">BLOCKS, </code><code class="sql comments">--表中数据所占的数据块数 </code></div>
<div class="line number3 index2 alt2"><code class="sql plain">EMPTY_BLOCKS, </code><code class="sql comments">--表中的空块数 </code></div>
<div class="line number4 index3 alt1"><code class="sql plain">AVG_SPACE, </code><code class="sql comments">--数据块中平均的使用空间 </code></div>
<div class="line number5 index4 alt2"><code class="sql plain">CHAIN_CNT, </code><code class="sql comments">--表中行连接和行迁移的数量 </code></div>
<div class="line number6 index5 alt1"><code class="sql plain">AVG_ROW_LEN </code><code class="sql comments">--每条记录的平均长度 </code></div>
<div class="line number7 index6 alt2"><code class="sql keyword">FROM</code> <code class="sql plain">USER_TABLES</code></div></div></td></tr></tbody></table></div></div>
<h5><span style="color: rgb(255,0,0)">3.3索引列的统计信息</span></h5>
<p>包含索引的深度（B-Tree的级别），索引叶级的块数量，集群因子（clustering_factor),&nbsp;唯一值的个数。</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_552164">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div>
<div class="line number6 index5 alt1">6</div>
<div class="line number7 index6 alt2">7</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">BLEVEL, </code><code class="sql comments">--索引的层数 </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">LEAF_BLOCKS, </code><code class="sql comments">--叶子结点的个数 </code></div>
<div class="line number3 index2 alt2"><code class="sql plain">DISTINCT_KEYS, </code><code class="sql comments">--唯一值的个数 </code></div>
<div class="line number4 index3 alt1"><code class="sql plain">AVG_LEAF_BLOCKS_PER_KEY, </code><code class="sql comments">--每个KEY的平均叶块个数&nbsp; </code></div>
<div class="line number5 index4 alt2"><code class="sql plain">AVG_DATA_BLOCKS_PER_KEY, </code><code class="sql comments">--每个KEY的平均数据块个数 </code></div>
<div class="line number6 index5 alt1"><code class="sql plain">CLUSTERING_FACTOR </code><code class="sql comments">--群集因子 </code></div>
<div class="line number7 index6 alt2"><code class="sql keyword">FROM</code> <code class="sql plain">USER_INDEXES</code></div></div></td></tr></tbody></table></div></div>
<h5><span style="color: rgb(255,0,0)">3.4 列的统计信息</span></h5>
<p>包含唯一的值个数，列最大小值，密度（选择率），数据分布（直方图信息），NUll值个数</p>
<div>
<div class="syntaxhighlighter  sql ie" id="highlighter_956215">
<table cellspacing="0" cellpadding="0" border="0">
<tbody>
<tr>
<td class="gutter">
<div class="line number1 index0 alt2">1</div>
<div class="line number2 index1 alt1">2</div>
<div class="line number3 index2 alt2">3</div>
<div class="line number4 index3 alt1">4</div>
<div class="line number5 index4 alt2">5</div>
<div class="line number6 index5 alt1">6</div>
<div class="line number7 index6 alt2">7</div>
<div class="line number8 index7 alt1">8</div></td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2"><code class="sql keyword">SELECT</code> <code class="sql plain">NUM_DISTINCT, </code><code class="sql comments">--唯一值的个数 </code></div>
<div class="line number2 index1 alt1"><code class="sql plain">LOW_VALUE, </code><code class="sql comments">--列上的最小值 </code></div>
<div class="line number3 index2 alt2"><code class="sql plain">HIGH_VALUE, </code><code class="sql comments">--列上的最大值 </code></div>
<div class="line number4 index3 alt1"><code class="sql plain">DENSITY, </code><code class="sql comments">--选择率因子（密度） </code></div>
<div class="line number5 index4 alt2"><code class="sql plain">NUM_NULLS, </code><code class="sql comments">--空值的个数 </code></div>
<div class="line number6 index5 alt1"><code class="sql plain">NUM_BUCKETS, </code><code class="sql comments">--直方图的BUCKET个数 </code></div>
<div class="line number7 index6 alt2"><code class="sql plain">HISTOGRAM </code><code class="sql comments">--直方图的类型 </code></div>
<div class="line number8 index7 alt1"><code class="sql keyword">FROM</code> <code class="sql plain">USER_TAB_COLUMNS</code></div></div></td></tr></tbody></table></div></div>
<div>对于统计信息的搜集，谈谈个人的几点理解： </div>
<div>1.统计信息默认是存放在数据字典表中的，也只有数据字典中的统计信息，才会影响到CBO。 </div>
<div>2.DBMS_STATS 提供的CREATE_STAT_TABLE 过程，只是生成一个用户自定义的特定格式的表，用来存放统计信息罢了，这个表中的统计信息是不会影响到统计信息的。 </div>
<div>3.GATHER 系列过程中，如果指定stattab，statid，statown 参数（也可以不指定），则是搜集的统计信息除了更新到数据字典外，还在statown 用户下的stattab 表中存放一份，标示为 statid; </div>
<div>4.EXPORT和IMPORT 系列的过程中,stattab,statid,statown 参数不能为空，分别表示把数据字典中的当前统计信息导出到用户自定义的表中，以及把用户表中的统计信息导入到数据字典中，很明显可以看出，这里的导入操作和上面GATHER 操作会改变统计信息，可能会引起执行执行计划的改变，因此要慎重操作。 </div>
<div>5.每次统计信息搜集前，将旧的统计信息备份起来是很有必要的；特别是保留一份或多份系统在稳定时期的统计信息也是很有必要的。 </div>
<div>6.多长时间搜集一次统计信息，对于统计信息如何备份和保留，搜集统计信息时如何选择合适的采样，并行，直方图设置等都比较重要，需要设计一个较好的统计信息搜集策略。</div>
<p>在OCP 10g考试中会有个跟统计信息相关的考试题：</p>
<p><span style="white-space: nowrap">1. In your Oracle 10g database , you have scheduled a job to update the optimizer statistics at 05:00 pm</span></p>
<p><span style="white-space: nowrap">every Friday. The job has successfully completed. Which three pieces of information would you check to</span></p>
<p><span style="white-space: nowrap">confirm that the statistics have been collected? (Choose three.)</span></p>
<p><span style="white-space: nowrap">A. average row size</span></p>
<p><span style="white-space: nowrap">B. last analyzed date</span></p>
<p><span style="white-space: nowrap">C. size of table in bytes</span></p>
<p><span style="white-space: nowrap">D. size of table in database blocks</span></p>
<p><span style="white-space: nowrap">E. number of free blocks in the free list</span></p>
<p><span style="white-space: nowrap">F. number of extents present in the table</span></p>
<p><span style="white-space: nowrap">Answer: ABD</span></p><img src ="http://www.blogjava.net/tjyhy590/aggbug/413754.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-16 19:08 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/16/413754.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle统计信息的收集、管理与清除</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/16/413753.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Fri, 16 May 2014 10:21:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/16/413753.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413753.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/16/413753.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413753.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413753.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: 以下测试环境为Oracle 10g 10.2.0.4版本，测试对Oracle的统计信息的收集与管理。首先依据dba_objects创建一张测试表：SQL&gt; create table eygle as select * from dba_objects;&nbsp;Table created对该表进行统计信息收集，这里未指定method_opt，则Oracle将采用 FOR ALL COL...&nbsp;&nbsp;<a href='http://www.blogjava.net/tjyhy590/archive/2014/05/16/413753.html'>阅读全文</a><img src ="http://www.blogjava.net/tjyhy590/aggbug/413753.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-16 18:21 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/16/413753.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>oracle sql日期相关</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/15/413701.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Thu, 15 May 2014 09:36:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/15/413701.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413701.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/15/413701.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413701.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413701.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: 获取昨天：select trunc(SYSDATE-1) &nbsp;from dual;检查一下：select to_char (trunc(SYSDATE-1),'yyyy-mm-dd HH24:MI:SS') from dual;获取上个月第一天00:00:00：&nbsp;select add_months(trunc(sysdate,'MON'),-1) from d...&nbsp;&nbsp;<a href='http://www.blogjava.net/tjyhy590/archive/2014/05/15/413701.html'>阅读全文</a><img src ="http://www.blogjava.net/tjyhy590/aggbug/413701.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-15 17:36 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/15/413701.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle 数据库启动的不同状态</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/11/413521.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Sun, 11 May 2014 11:54:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/11/413521.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413521.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/11/413521.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413521.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413521.html</trackback:ping><description><![CDATA[<p><font face="Verdana">Oracle数据库启动分为三个步骤：</font></p>
<p><font face="Verdana">nomount，找到初始化文件pfile或者spfile，创建SGA并启动后台进程但不允许访问数据库。</font></p>
<p><font face="Verdana">mount，根据初始化文件找到控制文件（Control File），为某些DBA活动装载数据库但不允许用户访问数据库。</font></p>
<p><font face="Verdana">open，根据控制文件找到数据文件（Data File），重做日志文件（Redo File），使用户可以访问数据库。</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">关闭数据库的4个不同命令</font></p>
<p><font face="Verdana">shutdown normal(等于shutdown)</font></p>
<p><font face="Verdana">正常是关闭的缺省方式正常的数据库关闭在下列情况下进行</font></p>
<p><font face="Verdana">&#8226; 不允许新的连接</font></p>
<p><font face="Verdana">&#8226; 等待会话结束</font></p>
<p><font face="Verdana">&#8226; 等待事务结束</font></p>
<p><font face="Verdana">&#8226; 做一个检查点并关闭数据文件</font></p>
<p><font face="Verdana">&#8226; 下一次启动时将不要求实例恢复</font></p>
<p><font face="Verdana">shutdown transactional</font></p>
<p><font face="Verdana">事务处理关闭防止客户丢失工作事务处理数据库关闭在下列情况下进行</font></p>
<p><font face="Verdana">&#8226; 不允许新的连接</font></p>
<p><font face="Verdana">&#8226; 不等待会话结束</font></p>
<p><font face="Verdana">&#8226; 等待事务结束</font></p>
<p><font face="Verdana">&#8226; 做一个检查点并关闭数据文件</font></p>
<p><font face="Verdana">&#8226; 下一次启动将不要求实例恢复</font></p>
<p><font face="Verdana">shutdown immediate</font></p>
<p><font face="Verdana">立即关闭数据库在下列情况下进行</font></p>
<p><font face="Verdana">&#8226; 不允许新的连接</font></p>
<p><font face="Verdana">&#8226; 不等待会话结束</font></p>
<p><font face="Verdana">&#8226; 不等待事务结束</font></p>
<p><font face="Verdana">&#8226; 未结束的事务自动回滚（rollback）</font></p>
<p><font face="Verdana">&#8226; 做一个检查点并关闭数据文件</font></p>
<p><font face="Verdana">&#8226; 下一次启动将不要求例程恢复</font></p>
<p><font face="Verdana">shutdown abort</font></p>
<p><font face="Verdana">如果正常和立即关闭选项不起作用可以中止当前数据库例程中止例程可以在下列情况下进行</font></p>
<p><font face="Verdana">&#8226; 不允许新的连接</font></p>
<p><font face="Verdana">&#8226; 不等待会话结束</font></p>
<p><font face="Verdana">&#8226; 不等待事务结束</font></p>
<p><font face="Verdana">&#8226; 不做检查点且没有关闭数据文件</font></p>
<p><font face="Verdana">&#8226; 下一次启动将要求实例恢复</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">启动数据库相关命令</font></p>
<p><font face="Verdana">startup（默认启动到open状态）</font></p>
<p><font face="Verdana">startup nomount</font></p>
<p><font face="Verdana">startup mount</font></p>
<p><font face="Verdana">alter database mount;</font></p>
<p><font face="Verdana">alter database open;</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">初始化文件</font></p>
<p><font face="Verdana">pfile，文本文件，可以手工编辑该文件</font></p>
<p><font face="Verdana">spfile，二进制文件，不能手工修改里面的参数，只能使用数据库命令进行修改，数据库启动默认使用spfile</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">查看初始化文件路径</font></p>
<p><font face="Verdana">show parameter spfile;</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">根据spfile创建pfile文件</font></p>
<p><font face="Verdana">create pfile from spfile;</font></p>
<p><font face="Verdana">create pfile='/u01/app/pfile.ora' fromspfile;</font></p>
<p><font face="Verdana">create spfile from pfile='/u01/app/pfile.ora';</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">查看控制文件的路径</font></p>
<p><font face="Verdana">select name from v$controlfile;</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">查看控制文件的内容，可以根据ctl.trc重建控制文件</font></p>
<p><font face="Verdana">alter database backup controlfile to trace as '/u01/app/ctl.trc';</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">查看数据文件的位置</font></p>
<p><font face="Verdana">select name from v$datafile;</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">查看重做日志文件的位置</font></p>
<p><font face="Verdana">select member from v$logfile;</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">数据库的密码文件</font></p>
<p><font face="Verdana">Windows，$ORACLE_HOME/database/PWDorcl.ora</font></p>
<p><font face="Verdana">Linux/Unix，$ORACLE_HOME/dbs/orapworcl</font></p>
<p><font face="Verdana">密码文件的作用是允许数据库的sysdba、sysoper用户通过口令来远登陆</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">查看数据库是否允许用户远程登陆数据库</font></p>
<p><font face="Verdana">show parameter remote_login_passwordfile;</font></p>
<p><font face="Verdana">如果remote_login_passwordfile为EXCLUSIVE则表示允许远程连接数据库</font></p>
<p><font face="Verdana">如果remote_login_passwordfile为NONE则表示不允许远程连接数据库</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">禁止用户远程登陆数据库（需要重启数据库生效）</font></p>
<p><font face="Verdana">alter system set remote_login_passwordfile=none scope=spfile;</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">表空间</font></p>
<p><font face="Verdana">select * from dba_tablespaces;</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">数据文件</font></p>
<p><font face="Verdana">select * from dba_data_files;</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">重做日志文件</font></p>
<p><font face="Verdana">select * from v$logfile;</font></p>
<p><font face="Verdana">&nbsp;</font></p>
<p><font face="Verdana">重做日志文件的状态</font></p>
<p><font face="Verdana">STALE表示数据已经提交到数据库中，空白状态表示正在使用该文件</font></p>
<p><font face="Verdana"></font>&nbsp;</p><img src ="http://www.blogjava.net/tjyhy590/aggbug/413521.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-11 19:54 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/11/413521.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>如何查看及解决最耗cpu的sql语句</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/11/413520.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Sun, 11 May 2014 11:44:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/11/413520.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413520.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/11/413520.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413520.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413520.html</trackback:ping><description><![CDATA[<table cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="t_f" id="postmessage_735361"><strong><font color="#000000"><font face="Calibri"><font style="font-size: 16pt"><font face="Calibri">1.</font>&nbsp; &nbsp;&nbsp; &nbsp;</font></font><font face="宋体"><font style="font-size: 16pt">如何查看及解决最耗</font></font><font style="font-size: 16pt"><font face="Calibri">CPU</font></font><font face="宋体"><font style="font-size: 16pt">的</font></font><font style="font-size: 16pt"><font face="Calibri">SQL</font></font><font face="宋体"><font style="font-size: 16pt">语句</font></font></font></strong><strong><font color="#000000"><font face="Cambria"><font face="Cambria">1.1.</font><font size="5">&nbsp;&nbsp;</font></font><font face="宋体">用</font><font face="Cambria">top</font><font face="宋体">监控服务器负载</font></font></strong> 
<table class="t_table" cellspacing="0">
<tbody>
<tr>
<td width="568">
<p align="right">
<p align="left"><font face="Calibri"><font color="#000000">[root@node1 ~]# top</font></font></p>
<p align="left"><font face="Calibri"><font color="#000000">top - 22:51:02 up 56 min,&nbsp;&nbsp;1 user,&nbsp;&nbsp;load average: 0.00, 0.00, 0.00</font></font></p>
<p align="left"><font face="Calibri"><font color="#000000">Tasks:&nbsp;&nbsp;96 total,&nbsp; &nbsp;1 running,&nbsp;&nbsp;95 sleeping,&nbsp; &nbsp;0 stopped,&nbsp; &nbsp;0 zombie</font></font></p>
<p align="left"><font face="Calibri"><font color="#000000">Cpu(s):&nbsp;&nbsp;0.0%us,&nbsp;&nbsp;0.0%sy,&nbsp;&nbsp;0.0%ni,100.0%id,&nbsp;&nbsp;0.0%wa,&nbsp;&nbsp;0.0%hi,&nbsp;&nbsp;0.0%si,&nbsp;&nbsp;0.0%st</font></font></p>
<p align="left"><font face="Calibri"><font color="#000000">Mem:&nbsp; &nbsp;1035096k total,&nbsp; &nbsp;351488k used,&nbsp; &nbsp;683608k free,&nbsp; &nbsp; 24140k buffers</font></font></p>
<p align="left"><font face="Calibri"><font color="#000000">Swap:&nbsp;&nbsp;2096472k total,&nbsp; &nbsp;&nbsp; &nbsp;&nbsp;&nbsp;0k used,&nbsp;&nbsp;2096472k free,&nbsp; &nbsp;270360k cached</font></font></p>
<p align="left"><font face="Calibri"><font color="#000000"></font></font></p>
<p align="left"><font color="#000000"><font face="Calibri">&nbsp;&nbsp;PID USER&nbsp; &nbsp;&nbsp; &nbsp;PR&nbsp;&nbsp;NI&nbsp;&nbsp;VIRT&nbsp;&nbsp;RES&nbsp;&nbsp;SHR S %CPU %MEM&nbsp; &nbsp; TIME+&nbsp;&nbsp;COMMAND&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp; </font></font></p>
<p align="left"><font color="#000000"><font face="Calibri">&nbsp; &nbsp; 1 root&nbsp; &nbsp;&nbsp; &nbsp;15&nbsp; &nbsp;0&nbsp;&nbsp;2084&nbsp;&nbsp;660&nbsp;&nbsp;560 S&nbsp;&nbsp;0.0&nbsp;&nbsp;0.1&nbsp; &nbsp;0:00.22 init&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp;&nbsp;</font></font></p>
<p align="left"><font color="#000000"><font face="Calibri">&nbsp; &nbsp; 2 root&nbsp; &nbsp;&nbsp; &nbsp;RT&nbsp;&nbsp;-5&nbsp; &nbsp;&nbsp;&nbsp;0&nbsp; &nbsp; 0&nbsp; &nbsp; 0 S&nbsp;&nbsp;0.0&nbsp;&nbsp;0.0&nbsp; &nbsp;0:00.00 migration/0&nbsp; &nbsp; </font></font></p>
</td></tr></tbody></table>
<p align="left"><font color="#000000"><font face="Calibri">&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;</font>如果发现<font face="Calibri">user</font>中的<font face="Calibri">CPU</font>过高，比如<font face="Calibri">oracle</font>中最高的进程<font face="Calibri">pid</font>为<font face="Calibri">1138782</font>，占<font face="Calibri">CPU27%</font>，则执行下一步。</font></p><strong><font color="#000000"><font face="Cambria"><font face="Cambria">1.2.</font><font size="5">&nbsp;&nbsp;</font></font><font face="宋体">查询数据库会话的</font><font face="Cambria">sid</font><font face="宋体">、</font><font face="Cambria">serial#</font></font></strong> 
<p align="left"><font color="#000000">进入数据库，根据<font face="Calibri">oracle</font>进程的<font face="Calibri">pid</font>查出对应数据库会话的<font face="Calibri">sid</font>、<font face="Calibri">serial#</font>：</font></p>
<table class="t_table" cellspacing="0">
<tbody>
<tr>
<td width="568">
<p align="right">
<p align="left"><font face="Calibri">select s.sid,s.serial#</font></p>
<p align="left"><font face="Calibri">from v$session s,v$process p</font></p>
<p align="left"><font face="Calibri">where s.paddr=p.addr and p.spid='1138782';</font></p>
</td></tr></tbody></table>
<p align="left"><font color="#000000"><font face="Calibri">&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;</font>查询出来的结果<font face="Calibri">sid</font>、<font face="Calibri">serial#</font>分别为<font face="Calibri">482</font>、<font face="Calibri">56767</font></font></p><strong><font color="#000000"><font face="Cambria"><font face="Cambria">1.3.</font><font size="5">&nbsp;&nbsp;</font></font><font face="宋体">查询</font><font face="Cambria">SQL</font><font face="宋体">语句</font></font></strong> 
<p align="left"><font color="#000000">根据数据库会话的<font face="Calibri">sid</font>查出具体的<font face="Calibri">SQL</font>语句：</font></p>
<table class="t_table" cellspacing="0">
<tbody>
<tr>
<td width="568">
<p align="right">
<p align="left"><font face="Calibri"><font color="#000000">desc v$sqltext</font></font></p>
</td></tr></tbody></table>
<p align="left"><font color="#000000">名称<font face="Calibri">&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp;&nbsp;</font>是否为空<font face="Calibri">? </font>类型</font></p>
<p align="left"><font face="Calibri"><font color="#000000">----------------------------------------- -------- --------------</font></font></p>
<p align="left"><font face="Calibri"><font color="#000000">ADDRESS&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp;&nbsp;RAW(4)</font></font></p>
<p align="left"><font face="Calibri"><font color="#000000">HASH_VALUE&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp;&nbsp;NUMBER</font></font></p>
<p align="left"><font face="Calibri"><font color="#000000">COMMAND_TYPE&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp;&nbsp;NUMBER</font></font></p>
<p align="left"><font face="Calibri"><font color="#000000">PIECE&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp;&nbsp;NUMBER</font></font></p>
<p align="left"><font face="Calibri"><font color="#000000">SQL_TEXT&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp; VARCHAR2(64)</font></font></p>
<p align="left"></p>
<table class="t_table" cellspacing="0">
<tbody>
<tr>
<td width="568">
<p align="right">
<p align="left"><font face="Calibri">select sql_text</font></p>
<p align="left"><font face="Calibri">from v$sqltext a</font></p>
<p align="left"><font face="Calibri">where a.hash_value=(select sql_hash_value from v$session b</font></p>
<p align="left"><font face="Calibri">&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp; where b.sid='&amp;sid')</font></p>
<p align="left"><font face="Calibri">order by piece;</font></p>
</td></tr></tbody></table>
<p align="left"><font color="#000000">输入<font face="Calibri"> sid </font>的值<font face="Calibri">:</font></font></p><strong><font color="#000000"><font face="Cambria"><font face="Cambria">1.4.</font><font size="5">&nbsp;&nbsp;</font></font><font face="宋体">处理</font><font face="Cambria">SQL</font><font face="宋体">语句</font></font></strong> 
<p align="left"><font color="#000000">如果<font face="Calibri">SQL</font>语句影响了数据库的运行，可以<font face="Calibri">kill</font>掉<font face="Calibri">SQL</font>语句的会话：</font></p>
<p align="left"><font color="#000000">&#9312;在数据库中杀死<font face="Calibri">SQL</font>语句的会话：</font></p>
<table class="t_table" cellspacing="0">
<tbody>
<tr>
<td width="568">
<p align="right">
<p align="left"><font face="Calibri"><font color="#000000">alter system kill session '482,56767';</font></font></p>
</td></tr></tbody></table>
<p align="left"><font color="#000000"><font face="Calibri">&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;</font>如果不能在数据库中杀死<font face="Calibri">SQL</font>语句，可在<font face="Calibri">LINUX</font>系统中强制杀死<font face="Calibri">Oracle</font>进程</font></p>
<p align="left"><font color="#000000"><font face="Calibri">&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp;</font>&#9313;在<font face="Calibri">linux</font>系统中强制杀死<font face="Calibri">oracle</font>进程</font></p>
<table class="t_table" cellspacing="0">
<tbody>
<tr>
<td width="568">
<p align="right">
<p align="left"><font face="Calibri"><font color="#000000">#kill -9 1138782</font></font></p>
</td></tr></tbody></table>
<p align="left"><font face="Calibri"><font color="#000000"></font></font></p><strong><font color="#000000"><font face="Cambria"><font face="Cambria">1.5.</font><font size="5">&nbsp;&nbsp;</font></font><font face="Cambria">SQL</font><font face="宋体">语句优化</font></font></strong> 
<p align="left"><font color="#000000">最后可以根据步骤（<font face="Calibri">3</font>）查询出来的<font face="Calibri">SQL</font>语句进行优化，以避免再次出现上述消耗<font face="Calibri">CPU</font>的情况。</font></p></td></tr></tbody></table><img src ="http://www.blogjava.net/tjyhy590/aggbug/413520.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-11 19:44 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/11/413520.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle 分区表的新增、修改、删除、合并。普通表转分区表方法 </title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/10/413484.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Sat, 10 May 2014 04:19:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/10/413484.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413484.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/10/413484.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413484.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413484.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: 一. 分区表理论知识Oracle提供了分区技术以支持VLDB(Very Large DataBase)。分区表通过对分区列的判断，把分区列不同的记录，放到不同的分区中。分区完全对应用透明。 Oracle的分区表可以包括多个分区，每个分区都是一个独立的段（SEGMENT），可以存放到不同的表空间中。查询时可以通过查询表来访问各个分区中的数据，也可以通过在查询时直接指定分区的方法来进行查询。 ...&nbsp;&nbsp;<a href='http://www.blogjava.net/tjyhy590/archive/2014/05/10/413484.html'>阅读全文</a><img src ="http://www.blogjava.net/tjyhy590/aggbug/413484.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-10 12:19 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/10/413484.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle分区表</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/07/413381.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Wed, 07 May 2014 14:53:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/07/413381.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413381.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/07/413381.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413381.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413381.html</trackback:ping><description><![CDATA[1.分区表的维护注意事项 
<ol><li>若分区表跨不同表空间，做导出、导入时目标数据库必须预建这些表空间。分表区各区所在表空间在做导入时目标数据库一定要预建这些表空间！这些表空间不一定是用户的默认表空间，只要存在即可。如果有一个不存在，就会报错！</li><li>默认时，对分区表的许多表维护操作会使全局索引不可用，标记成UNUSABLE。 那么就必须重建整个全局索引或其全部分区。如果已被分区，Oracle 允许在用于维护操作的ALTER TABLE 语句中指定UPDATE GLOBAL INDEXES 来重载这个默认特性，指定这个子句也就告诉Oracle 当它执行维护操作的DDL 语句时更新全局索引，这提供了如下好处： 
<ol><li>在操作基础表的同时更新全局索引这就不需要后来单独地重建全局索引；</li><li>因为没有被标记成UNUSABLE， 所以全局索引的可用性更高了，甚至正在执行分区的DDL 语句时仍然可用索引来访问表中的其他分区,避免了查询所有失效的全局索引的名字以便重建它们；</li></ol></li></ol>
<p>另外在指定UPDATE GLOBAL INDEXES 之前还要考虑如下性能因素:</p>
<ol><li>因为要更新事先被标记成UNUSABLE 的索引，所以分区的DDL 语句要执行更长时间，当然这要与先不更新索引而执行DDL 然后再重建索引所花的时间做个比较，一个适用的规则是如果分区的大小小于表的大小的5% ，则更新索引更快一点；</li><li>DROP TRUNCATE 和EXCHANGE 操作也不那么快了，同样这必须与先执行DDL 然后再重建所有全局索引所花的时间做个比较；</li><li>要登记对索引的更新并产生重做记录和撤消记录，重建整个索引时可选择NOLOGGING；</li><li>重建整个索引产生一个更有效的索引，因为这更利于使用空间，再者重建索引时允许修改存储选项；</li><li>分区索引结构表不支持UPDATE GLOBAL INDEXES 子句。 </li></ol>2.普通表变为分区表 
<p>将已存在数据的普通表转变为分区表，没有办法通过修改属性的方式直接转化为分区表，必须通过重建的方式进行转变，一般可以有三种方法，视不同场景使用：</p>2.1方法一：利用原表重建分区表。 
<p><pre>CREATE TABLE T (ID NUMBER PRIMARY KEY, TIME DATE); 

INSERT INTO t
  SELECT Rownum, SYSDATE - Rownum FROM Dba_Objects WHERE Rownum &lt;= 5000;
COMMIT;

CREATE TABLE T_NEW (ID, TIME) PARTITION BY RANGE (TIME) 
 (PARTITION P1 VALUES LESS THAN (TO_DATE('2000-1-1', 'YYYY-MM-DD')), 
 PARTITION P2 VALUES LESS THAN (TO_DATE('2002-1-1', 'YYYY-MM-DD')), 
 PARTITION P3 VALUES LESS THAN (TO_DATE('2005-1-1', 'YYYY-MM-DD')), 
 PARTITION P4 VALUES LESS THAN (MAXVALUE))
 AS SELECT ID, TIME FROM T; 

RENAME T TO T_OLD; 

RENAME T_NEW TO T; </pre>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>优点：方法简单易用，由于采用DDL语句，不会产生UNDO，且只产生少量REDO，效率相对较高，而且建表完成后数据已经在分布到各个分区中了。 </p>
<p>不足：对于数据的一致性方面还需要额外的考虑。由于几乎没有办法通过手工锁定T表的方式保证一致性，在执行CREATE TABLE语句和RENAME T_NEW TO T语句直接的修改可能会丢失，如果要保证一致性，需要在执行完语句后对数据进行检查，而这个代价是比较大的。另外在执行两个RENAME语句之间执行的对T的访问会失败。</p>
<p>适用性：适用于修改不频繁的表，在闲时进行操作，表的数据量不宜太大。 </p>2.2方法二：使用交换分区的方法 
<p><pre>Drop table t;
CREATE TABLE T (ID NUMBER PRIMARY KEY, TIME DATE); 
INSERT INTO t
  SELECT Rownum, SYSDATE - Rownum FROM Dba_Objects WHERE Rownum &lt;= 5000;
COMMIT;

CREATE TABLE T_NEW (ID NUMBER PRIMARY KEY, TIME DATE) PARTITION BY RANGE (TIME) 
 (PARTITION P1 VALUES LESS THAN (TO_DATE('2005-9-1', 'YYYY-MM-DD')), 
 PARTITION P2 VALUES LESS THAN (MAXVALUE)); 

ALTER TABLE T_NEW EXCHANGE PARTITION P1 WITH TABLE T; 

RENAME T TO T_OLD; 

RENAME T_NEW TO T; </pre>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>优点：只是对数据字典中分区和表的定义进行了修改，没有数据的修改或复制，效率最高。如果对数据在分区中的分布没有进一步要求的话，实现比较简单。在执行完RENAME操作后，可以检查T_OLD中是否存在数据，如果存在的话，直接将这些数据插入到T中，可以保证对T插入的操作不会丢失。</p>
<p>不足：仍然存在一致性问题，交换分区之后RENAME T_NEW TO T之前，查询、更新和删除会出现错误或访问不到数据。如果要求数据分布到多个分区中，则需要进行分区的SPLIT操作，会增加操作的复杂度，效率也会降低。</p>
<p>适用性：适用于包含大数据量的表转到分区表中的一个分区的操作。应尽量在闲时进行操作。 </p>2.3方法三：Oracle9i以上版本，利用在线重定义功能 
<p><pre>Drop table t;
CREATE TABLE T (ID NUMBER PRIMARY KEY, TIME DATE); 
INSERT INTO T
 SELECT ROWNUM, SYSDATE - ROWNUM FROM DBA_OBJECTS WHERE ROWNUM &lt;= 5000;
COMMIT;

EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE(USER, 'T'); 

PL/SQL 过程已成功完成。 

CREATE TABLE T_NEW (ID NUMBER PRIMARY KEY, TIME DATE) PARTITION BY RANGE (TIME) 
 (PARTITION P1 VALUES LESS THAN (TO_DATE('2004-7-1', 'YYYY-MM-DD')), 
 PARTITION P2 VALUES LESS THAN (TO_DATE('2005-1-1', 'YYYY-MM-DD')), 
 PARTITION P3 VALUES LESS THAN (TO_DATE('2005-7-1', 'YYYY-MM-DD')), 
 PARTITION P4 VALUES LESS THAN (MAXVALUE)); 

表已创建。 

EXEC DBMS_REDEFINITION.START_REDEF_TABLE(USER, 'T', 'T_NEW'); 

PL/SQL 过程已成功完成。 

EXEC DBMS_REDEFINITION.FINISH_REDEF_TABLE(USER, 'T', 'T_NEW'); 

PL/SQL 过程已成功完成。 </pre>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>优点：保证数据的一致性，在大部分时间内，表T都可以正常进行DML操作。只在切换的瞬间锁表，具有很高的可用性。这种方法具有很强的灵活性，对各种不同的需要都能满足。而且，可以在切换前进行相应的授权并建立各种约束，可以做到切换完成后不再需要任何额外的管理操作。</p>
<p>不足：实现上比上面两种略显复杂。 </p>
<p>适用性：适用于各种情况。 </p>
<p>这里只给出了在线重定义表的一个最简单的例子，详细的描述和例子可以参考下面两篇文章。</p>
<p>Oracle的在线重定义表功能：<a href="http://blog.itpub.net/post/468/12855" target="_blank" rel="nofollow">http://blog.itpub.net/post/468/12855</a></p>
<p>Oracle的在线重定义表功能（二）：<a href="http://blog.itpub.net/post/468/12962" target="_blank" rel="nofollow">http://blog.itpub.net/post/468/12962</a></p>2.4把一个已存在数据的大表改成分区表： 
<p>第一种（表不是太大）：</p>
<p><pre>--1.把原表改名：
rename xsb1 to xsb2;
--2.创建分区表：
CREATE TABLE xsb1
 PARTITION BY LIST (c_test) 
 (PARTITION xsb1_p1 VALUES (1),
 PARTITION xsb1_p2 VALUES (2),
 PARTITION xsb1_p0 VALUES (default))
 nologging AS SELECT * FROM xsb2;
--3.将原表上的触发器、主键、索引等应用到分区表上；
--4.删除原表：
drop table xsb2;</pre><br />
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>第二种(表很大)：</p>
<p><pre>--1. 创建分区表：
CREATE TABLE x PARTITION BY LIST (c_test) [range ()]
 (PARTITION p0 VALUES [less than ](1) tablespace tbs1,
 PARTITION p2 VALUES (2) tablespace tbs1,
 PARTITION xsb1_p0 VALUES ([maxvalue]default))
 AS SELECT * FROM xsb2 [where 1=2];
--2. 交换分区 
alter table x exchange partition p0 with table bsvcbusrundatald ;
--3. 原表改名
alter table bsvcbusrundatald rename to x0;
--4. 新表改名
alter table x rename to bsvcbusrundatald ;
--5. 删除原表
drop table x0;
--6. 创建新表触发器和索引
create index ind_busrundata_lp on bsvcbusrundatald(。。。) local tablespace tbs_brd_ind ;</pre><br />
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>或者：</p>
<p>1. 规划原大表中数据分区的界限，原则上将原表中近期少量数据复制至另一表；</p>
<p>2. 暂停原大表中的相关触发器；</p>
<p>3. 删除原大表中近期数据；</p>
<p>4. 改名原大表名称；</p>
<p>5. 创建分区表；</p>
<p>6. 交换分区；</p>
<p>7. 重建相关索引及触发器（先删除之再重建）.</p>
<p>参考脚本：</p>
<p><pre>select count(*) from t1 where recdate&gt;sysdate-2;

create table x2 nologging as select * from t1 where recdate&gt;trunc(sysdate-2);

alter triger trg_t1 disable;

delete t1 where recdate&gt;sysdate-2;

commit;

rename t1 to x1;

create table t1 [nologging] partition by range(recdate)

(partition pbefore values less than (trunc(sysdate-2)),

partition pmax values less than (maxvalue))

as select * from x1 where 1=2;

alter table t1 exchange partition pbefore with table x1;

alter table t1 exchange partition pmax with table x2;

drop table x2;

--重建触发器

drop table x1;
</pre><br />
<p>&nbsp;</p>
<p>&nbsp;</p>3.分区的方法： 
<ol><li>范围分区Range</li><li>散列分区Hash</li><li>列表分区List</li><li>组合范围-散列分区Range-Hash</li><li>组合范围-列表分区Range-List</li></ol>
<p>可对索引和表分区。全局索引只能按范围分区，但可以将其定义在任何类型的分区或非分区表上。通常全局索引比局部索引需要更多的维护。</p>
<p>一般组建局部索引，以便反映其基础表的结构。它与基础表是等同分区的，即它与基础表在同样的列上分区，创建同样数量的分区或子分区，设置与基础表相对应的同样的分区边界。对局部索引而言，当维护活动影响分区时，会自动维护索引分区。这保证了索引与基础表之间的等同分区。</p>
<p>关于范围分区Range：</p>
<p>要想将行映射到基于列值范围的分区，就使用范围分区方法。当数据可以被划分成逻辑范围时如年度中的月份，这种类型的分区就有用了。当数据在整个范围中能被均等地划分时性能最好。如果靠范围的分区会由于不均等的划分而导致分区在大小上明显不同时，就需要考虑其他的分区方法。</p>
<p>关于散列分区Hash：</p>
<p>如果数据不那么容易进行范围分区，但为了性能和管理的原因又想分区时，就使用散列分区方法。散列分区提供了一种在指定数量的分区中均等地划分数据的方法。基于分区键的散列值将行映射到分区中。创建和使用散列分区会给你提供了一种很灵活的放置数据的方法，因为你可以通过在I/O 驱动器之间播撒(摘掉)这些均等定量的分区，来影响可用性和性能。</p>
<p>关于列表分区List：</p>
<p>当你需要明确地控制如何将行映射到分区时，就使用列表分区方法。可以在每个分区的描述中为该分区列指定一列离散值，这不同于范围分区，在那里一个范围与一个分区相关，这也不同于散列分区，在那里用户不能控制如何将行映射到分区。列表分区方法是特意为遵从离散值的模块化数据划分而设计的。范围分区或散列分区不那么容易做到这一点。进一步说列表分区可以非常自然地将无序的和不相关的数据集进行分组和组织到一起。</p>
<p>与范围分区和散列分区所不同，列表分区不支持多列分区。如果要将表按列分区，那么分区键就只能由表的一个单独的列组成，然而可以用范围分区或散列分区方法进行分区的所有的列,都可以用列表分区方法进行分区。</p>
<p>关于组合范围-散列分区：</p>
<p>范围和散列技术的组合，首先对表进行范围分区，然后用散列技术对每个范围分区再次分区。给定的范围分区的所有子分区加在一起表示数据的逻辑子集。 </p>
<p>关于组合范围-列表分区：</p>
<p>范围和列表技术的组合，首先对表进行范围分区，然后用列表技术对每个范围分区再次分区。与组合范围-散列分区不同的是，每个子分区的所有内容表示数据的逻辑子集，由适当的范围和列表分区设置来描述。</p>
<p><span>注意</span>：创建或更改分区表时可以指定行移动子句，即ENABLE ROW MOVEMENT 或者DISABLE ROW MOVEMENT ，当其键被更改时，该子句启用或停用将行迁移到一个新的分区。默认值为DISABLE ROW MOVEMENT。</p>
<p>如果表中预期的数据量较大，通常都需要考虑使用分区表，确定使用分区表后，还要确定什么类型的分区（range partition、hash partition、list partition等）、分区区间大小等。分区的创建最好与程序有某种默契，比如创建一个分区表，按自然月份定义分区的，但程序却在查询时默认的开始时间与结束时间是：当前日期-30至当前日期，比如当天是9.18号，那查询条件被产生为8.18-9.18，结果分区后并不没有大幅提高性能。为此将程序的查询日期做了调整，按自然月查询，系统的负载小了很多。</p>4.补充资料 
<p>从Oracle8.0开始支持表分区（MSSQL2005开始支持表分区）。</p>
<p>Oracle9i 分区能够提高许多应用程序的可管理性、性能与可用性。分区可以将表、索引及索引编排表进一步划分，从而可以更精细地对这些数据库对象进行管理和访问。Oracle 提供了种类繁多的分区方案以满足所有的业务需要。另外，由于在 SQL 语句中是完全透明的，所以分区可以用于几乎所有的应用程序。</p>
<p>分区表允许将数据分成被称为分区甚至子分区的更小的更好管理的块。索引也可以这么分区。每个分区可以被单独管理，可以不依赖于其他分区而单独发挥作用，因此提供了一个更有利于可用性和性能的结构。</p>
<p>分区可以提高可管理性、性能与可用性，从而给各种各样的应用程序带来极大的好处。通常，分区可以使某些查询以及维护操作的性能大大提高。此外，分区还能够在很大程度上简化日常管理任务。分区还使数据库设计人员和管理员能够解决尖端应用程序带来的最难的问题。分区是建立上亿万字节数据系统或需要极高可用性系统的关键工具。</p>
<p>在多CPU配置环境下，如果打算使用并行执行，则分区提供了另一种并行的方法。通过给表或索引的不同分区分配不同的并行执行服务器，就可以并行执行对分区表和分区索引的操作。</p>
<p>表或索引的分区和子分区都共享相同的逻辑属性。例如表的所有分区或子分区共享相同的列和约束定义，一个索引的分区或子分区共享相同的索引选项。然而它们可以具有不同的物理属性如表空间。</p>
<p>尽管不需要将表或索引的每个分区或子分区放在不同的表空间，但这样做更好。将分区存储到不同的表空间能够：</p>
<ol><li>减少数据在多个分区中冲突的可能性</li><li>可以单独备份和恢复每个分区</li><li>控制分区与磁盘驱动器之间的映射对平衡I/O 负载是重要的</li><li>改善可管理性可用性和性能</li></ol>
<p>分区操作对现存的应用和运行在分区表上的标准DML 语句来说是透明的。但是可以通过在DML 中使用分区扩展表或索引的名字来对应用编程，使其利用分区的优点。</p>
<p>可以使用SQL*Loader、Import 和Export 工具来装载或卸载分区表中的数据。这些工具都是支持分区和子分区的。</p>4.1分区技术能够提高数据库的可管理性： 
<p>使用分区技术，维护操作可集中于表的特定部分。例如，数据库管理员可以只对表的一部分做备份，而不必对整个表做备份。对整个数据库对象的维护操作，可以在每个分区的基础上进行，从而将维护工作分解成更容易管理的小块。</p>
<p>分区技术提高可管理性的一个典型用法是支持数据仓库中的&#8216;滚动视窗&#8217;加载进程。假设数据库管理员每周向表中加载新数据。该表可以是范围分区，以便每个分区包含一周的数据。加载进程只是简单地添加新的分区。添加一个新分区的操作比修改整个表效率高很多，因为数据库管理员不需要修改任何其他分区。从分区后的表中去除数据也是一样。你只要用一个很简便快捷的数据字典操作删掉一个分区，而不必发出使用大量资源和调动所有要删除的数据的 &#8216;DELETE&#8217; 命令。</p>4.2分区技术能够提高数据库的性能: 
<p>由于减少了所检查或操作的数据数量，同时允许并行执行，Oracle9i 的分区功能提供了性能上的优势。这些性能包括： </p>
<ol><li>分区修整：分区修整是用分区技术提高性能的最简单最有价值的手段。分区修整常常能够将查询性能提高几个数量级。例如，假定应用程序中有包含定单历史记录的定单表，该表用周进行了分区。查询一周的定单只需访问该定单表的一个分区。如果该定单表包含两年的历史记录，这个查询只需要访问一个而不是一百零四个分区。该查询的执行速度因为分区修整而有可能快一百倍。分区修整能与所有其他 Oracle 性能特性协作。Oracle 公司将把分区修整技术与索引技术、连结技术和并行访问方法一起联合使用。</li><li>分区智能联接：分区功能可以通过称为分区智能联接的技术提高多表联接的性能。当两个表要联接在一起，而且每个表都用联接关键字来分区时，就可以使用分区智能联接。分区智能联接将大型联接分解成较小的发生在各个分区间的联接，从而用较少的时间完成全部联接。这就给串行和并行的执行都能带来显著的性能改善。</li><li>更新和删除的并行执行：分区功能能够无限地并行执行 UPDATE、DELETE 与 MERGE 语句。当访问分区或未分区的数据库对象时Oracle 将并行处理 SELECT 与 INSERT 语句。当不使用位图索引时，也可以对分区或未分区的数据库对象并行处理 UPDATE、DELETE 和 MERGE 语句。为了对有位图索引的对象并行处理那些操作，目标表必须先分区。这些 SQL 语句的并行执行可以大大提高性能，特别是提高 UPDATE 与 DELETE 或 MERGE 操作涉及大量数据时的性能。</li></ol>4.3分区技术提高可用性： 
<p>分区的数据库对象具有分区独立性。该分区独立性特点可能是高可用性战略的一个重要部分，例如，如果分区表的分区不能用，但该表的所有其他分区仍然保持在线并可用。那么这个应用程序可以继续针对该分区表执行查询和事务处理，只要不是访问那个不可用的分区，数据库操作仍然能够成功运行。 数据库管理员可以指定各分区存放在不同的表空间里，从而让管理员独立于其它表分区针对每个分区进行备份与恢复操作。 还有，分区功能可以减少计划停机时间。性能由于分区功能得到了改善，使数据库管理员在相对较小的批处理窗口完成大型数据库对象的维护工作。<br /></p><img src ="http://www.blogjava.net/tjyhy590/aggbug/413381.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-07 22:53 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/07/413381.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>普通表转分区表和交换分区（oracle） </title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/07/413380.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Wed, 07 May 2014 14:31:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/07/413380.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413380.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/07/413380.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413380.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413380.html</trackback:ping><description><![CDATA[<p class=""><span>将普通表转换成分区表有4种方法：&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;1. Export/import&nbsp;method&nbsp;&nbsp;<br /><br /></span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;2. </span><span class="keyword">Insert</span><span>&nbsp;</span><span class="keyword">with</span><span>&nbsp;a&nbsp;subquery&nbsp;method&nbsp;&nbsp;<br /><br /></span><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 3. Partition&nbsp;exchange&nbsp;method&nbsp;&nbsp;<br /><br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 4. </span><span>DBMS_REDEFINITION&nbsp;&nbsp;</span><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword"><br />&nbsp;&nbsp;&nbsp;&nbsp;select</span><span>&nbsp;*&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_user_info_test;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="comment"><br />&nbsp;&nbsp;&nbsp;&nbsp;--方法一 </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">&nbsp;&nbsp;&nbsp;&nbsp;drop</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;purge;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">create</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test(phone,part)&nbsp;nologging&nbsp;&nbsp;partition&nbsp;</span><span class="keyword">by</span><span>&nbsp;list(part)&nbsp;&nbsp;</span></span></p>
<p class=""><span>(&nbsp;&nbsp;</span></p>
<p class="alt"><span>partition&nbsp;p0&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'0'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class=""><span>partition&nbsp;p1&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'1'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>partition&nbsp;p2&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'2'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class=""><span>partition&nbsp;p3&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'3'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>partition&nbsp;p4&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'4'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class=""><span>partition&nbsp;p5&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'5'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>partition&nbsp;p6&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'6'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class=""><span>partition&nbsp;p7&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'7'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>partition&nbsp;p8&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'8'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class=""><span>partition&nbsp;p9&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'9'</span><span>)&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>)&nbsp;&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">as</span><span>&nbsp;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;user_mobile&nbsp;phone,substr(user_mobile,-1,1)&nbsp;part&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">from</span><span>&nbsp;t_user_info_test;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;*&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p0);&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;*&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;</span><span class="keyword">where</span><span>&nbsp;part=</span><span class="string">'0'</span><span>;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="comment">--方法二&nbsp;交换分区 </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;这种方法只是对数据字典中分区和表的定义进行了修改，没有数据的修改或复制，效率最高。适用于包含大数据量的表转到分区表中的一个分区的操作。尽量在闲时进行操作。&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>交换分区的操作步骤如下：&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;1.&nbsp;创建分区表，假设有2个分区，P1，P2.&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;2.&nbsp;创建表A存放P1规则的数据。&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;3.&nbsp;创建表B&nbsp;存放P2规则的数据。&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;4.&nbsp;用表A&nbsp;和P1&nbsp;分区交换。&nbsp;把表A的数据放到到P1分区&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;5.&nbsp;用表B&nbsp;和p2&nbsp;分区交换。&nbsp;把表B的数据存放到P2分区。&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">create</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_0&nbsp;nologging&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">as</span><span>&nbsp;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;user_mobile&nbsp;phone,substr(user_mobile,-1,1)&nbsp;part&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">from</span><span>&nbsp;t_user_info_test&nbsp;</span><span class="keyword">where</span><span>&nbsp;substr(user_mobile,-1,1)=</span><span class="string">'0'</span><span>;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;</span><span class="keyword">where</span><span>&nbsp;part=</span><span class="string">'0'</span><span>;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="comment">--4410 </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_user_info_test&nbsp;</span><span class="keyword">where</span><span>&nbsp;substr(user_mobile,-1,1)=</span><span class="string">'0'</span><span>;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="comment">--4410 </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;exchange&nbsp;partition&nbsp;p0&nbsp;</span><span class="keyword">with</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_0;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">delete</span><span>&nbsp;</span><span class="keyword">from</span><span>&nbsp;&nbsp;&nbsp;t_phone_test_0;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;</span><span class="keyword">where</span><span>&nbsp;part=</span><span class="string">'0'</span><span>;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test_0;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">insert</span><span>&nbsp;</span><span class="keyword">into</span><span>&nbsp;t_phone_test(phone,part)&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'15267046070'</span><span>,</span><span class="string">'0'</span><span>);&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="comment">--p0一条数据，t_phone_test_0里4410条数据，交换之后p0是4410，t_phone_test_0是1，再执行一次数据又换回来了。 </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">insert</span><span>&nbsp;</span><span class="keyword">into</span><span>&nbsp;t_phone_test_0(phone,part)&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'15267046070'</span><span>,</span><span class="string">'1'</span><span>);&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;exchange&nbsp;partition&nbsp;p0&nbsp;</span><span class="keyword">with</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_0;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">delete</span><span>&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test_0&nbsp;</span><span class="keyword">where</span><span>&nbsp;part=</span><span class="string">'1'</span><span>;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="comment">--合并分区 </span><span>&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="comment">----alter&nbsp;table&nbsp;tbname&nbsp;merge&nbsp;partitions/subpartitions&nbsp;pt1,pt2&nbsp;into&nbsp;partition/subpartition&nbsp;pt3; </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;merge&nbsp;partitions&nbsp;p0,p1&nbsp;</span><span class="keyword">into</span><span>&nbsp;partition&nbsp;p0;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;</span><span class="keyword">where</span><span>&nbsp;part=</span><span class="string">'0'</span><span>;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;</span><span class="keyword">where</span><span>&nbsp;part=</span><span class="string">'1'</span><span>;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p0);&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p1);&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;</span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;&nbsp;</span><span class="keyword">add</span><span>&nbsp;partition&nbsp;p10&nbsp;</span><span class="keyword">values</span><span>(</span><span class="keyword">default</span><span>);&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">insert</span><span>&nbsp;</span><span class="keyword">into</span><span>&nbsp;t_phone_test(phone,part)&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'15267046010'</span><span>,</span><span class="string">'10'</span><span>);&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">insert</span><span>&nbsp;</span><span class="keyword">into</span><span>&nbsp;t_phone_test(phone,part)&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'15267046020'</span><span>,</span><span class="string">'20'</span><span>);&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;*&nbsp;</span><span class="keyword">from</span><span>&nbsp;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="comment">-- </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;</span><span class="keyword">drop</span><span>&nbsp;partition&nbsp;p10;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;</span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;&nbsp;</span><span class="keyword">add</span><span>&nbsp;partition&nbsp;p10&nbsp;</span><span class="keyword">values</span><span>(&nbsp;</span><span class="string">'10'</span><span>);&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;exchange&nbsp;partition&nbsp;p10&nbsp;</span><span class="keyword">with</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_10;&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="comment">--ORA-14097:&nbsp;column&nbsp;type&nbsp;or&nbsp;size&nbsp;mismatch&nbsp;in&nbsp;ALTER&nbsp;TABLE&nbsp;EXCHANGE&nbsp;PARTITION </span><span>&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;T_PHONE_TEST_10&nbsp;</span><span class="keyword">modify</span><span>&nbsp;PART&nbsp;VARCHAR2(2);&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;merge&nbsp;partitions&nbsp;p0,p10&nbsp;</span><span class="keyword">into</span><span>&nbsp;partition&nbsp;p0;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="comment">--此时p0中有p0和p10的数据，但是p0的list不再是0而是0和10 </span><span>&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;partition&nbsp;P0&nbsp;</span><span class="keyword">values</span><span>&nbsp;(</span><span class="string">'10'</span><span>,&nbsp;</span><span class="string">'0'</span><span>)&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;tablespace&nbsp;APP_DATAN&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;pctfree&nbsp;10&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;initrans&nbsp;1&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;maxtrans&nbsp;255&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;storage&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;(&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;initial&nbsp;1M&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span class="keyword">next</span><span>&nbsp;1M&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;minextents&nbsp;1&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;maxextents&nbsp;unlimited&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;pctincrease&nbsp;0&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;),&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;exchange&nbsp;partition&nbsp;p0&nbsp;</span><span class="keyword">with</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_10;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;</span><span class="keyword">drop</span><span>&nbsp;partition&nbsp;p0;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;&nbsp;</span><span class="keyword">add</span><span>&nbsp;partition&nbsp;p0&nbsp;</span><span class="keyword">values</span><span>(&nbsp;</span><span class="string">'0'</span><span>);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;exchange&nbsp;partition&nbsp;p0&nbsp;</span><span class="keyword">with</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_10;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">drop</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_10&nbsp;purge;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">create</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_10&nbsp;nologging&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">as</span><span>&nbsp;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;user_mobile&nbsp;phone,substr(user_mobile,-2,2)&nbsp;part&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">from</span><span>&nbsp;t_user_info_test&nbsp;</span><span class="keyword">where</span><span>&nbsp;substr(user_mobile,-2,2)=</span><span class="string">'10'</span><span>;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">drop</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_0&nbsp;purge;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">create</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_0&nbsp;nologging&nbsp;&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">as</span><span>&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;&nbsp;phone,substr(phone,-1,1)&nbsp;part&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">from</span><span>&nbsp;t_phone_test_10;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;exchange&nbsp;partition&nbsp;p0&nbsp;</span><span class="keyword">with</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_0;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;*&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test_10;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p0);&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p10);&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test_10;&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test_0;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;substr(</span><span class="string">'123456'</span><span>,-1,1),substr(</span><span class="string">'123456'</span><span>,-2,2),substr(</span><span class="string">'123456'</span><span>,-3,2)&nbsp;</span><span class="keyword">from</span><span>&nbsp;dual;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="comment">--------------------------------------------------------- </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span>1.创建分区表&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">drop</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;purge;&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">create</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test(phone,part)&nbsp;nologging&nbsp;&nbsp;partition&nbsp;</span><span class="keyword">by</span><span>&nbsp;list(part)&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>(&nbsp;&nbsp;</span></p>
<p class=""><span>partition&nbsp;p0&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'0'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>partition&nbsp;p1&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'1'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class=""><span>partition&nbsp;p2&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'2'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>partition&nbsp;p3&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'3'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class=""><span>partition&nbsp;p4&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'4'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>partition&nbsp;p5&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'5'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class=""><span>partition&nbsp;p6&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'6'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>partition&nbsp;p7&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'7'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class=""><span>partition&nbsp;p8&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'8'</span><span>),&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>partition&nbsp;p9&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'9'</span><span>)&nbsp;&nbsp;</span></span></p>
<p class=""><span>)&nbsp;&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">as</span><span>&nbsp;&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;user_mobile&nbsp;phone,substr(user_mobile,-1,1)&nbsp;part&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">from</span><span>&nbsp;t_user_info_test;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p0);</span><span class="comment">--4410 </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p10);&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test_10;&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test_0;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>2.创建基表&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">drop</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_10&nbsp;purge;&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">create</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_10&nbsp;nologging&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">as</span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;&nbsp;phone,substr(phone,-2,2)&nbsp;part&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;</span><span class="keyword">where</span><span>&nbsp;substr(phone,-2,2)=</span><span class="string">'10'</span><span>;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test_10;</span><span class="comment">--406 </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="comment">--ORA-14097:&nbsp;column&nbsp;type&nbsp;or&nbsp;size&nbsp;mismatch&nbsp;in&nbsp;ALTER&nbsp;TABLE&nbsp;EXCHANGE&nbsp;PARTITION </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;T_PHONE_TEST_10&nbsp;</span><span class="keyword">modify</span><span>&nbsp;PART&nbsp;VARCHAR2(2);&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>3.添加分区&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;&nbsp;</span><span class="keyword">add</span><span>&nbsp;partition&nbsp;p10&nbsp;</span><span class="keyword">values</span><span>(&nbsp;</span><span class="string">'10'</span><span>);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p10);</span><span class="comment">--0 </span><span>&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>4.交换分区&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;exchange&nbsp;partition&nbsp;p10&nbsp;</span><span class="keyword">with</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_10;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p10);</span><span class="comment">--406 </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span>5.合并分区&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;merge&nbsp;partitions&nbsp;p0,p10&nbsp;</span><span class="keyword">into</span><span>&nbsp;partition&nbsp;p0;&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p0);</span><span class="comment">--4816 </span><span>&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="comment">--此时p0中有p0和p10的数据，但是p0的list不再是0而是0和10 </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;partition&nbsp;P0&nbsp;</span><span class="keyword">values</span><span>&nbsp;(</span><span class="string">'10'</span><span>,&nbsp;</span><span class="string">'0'</span><span>)&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;tablespace&nbsp;APP_DATAN&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;pctfree&nbsp;10&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;initrans&nbsp;1&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;maxtrans&nbsp;255&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;storage&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;(&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;initial&nbsp;1M&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span class="keyword">next</span><span>&nbsp;1M&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;minextents&nbsp;1&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;maxextents&nbsp;unlimited&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;pctincrease&nbsp;0&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;&nbsp;&nbsp;),&nbsp;&nbsp;</span></p>
<p class="alt"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></p>
<p class=""><span>6.交换分区&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;exchange&nbsp;partition&nbsp;p0&nbsp;</span><span class="keyword">with</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_10;&nbsp;&nbsp;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p0);</span><span class="comment">--0 </span><span>&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test_10;</span><span class="comment">--4816 </span><span>&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span>6.删除分区&nbsp;和添加分区&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;&nbsp;</span><span class="keyword">drop</span><span>&nbsp;partition&nbsp;p0;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;&nbsp;</span><span class="keyword">add</span><span>&nbsp;partition&nbsp;p0&nbsp;</span><span class="keyword">values</span><span>(</span><span class="string">'0'</span><span>);&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span>7.筛选数据&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">drop</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_0&nbsp;purge;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">create</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_0&nbsp;nologging&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">as</span><span>&nbsp;&nbsp;</span></span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;&nbsp;phone,substr(phone,-1,1)&nbsp;part&nbsp;&nbsp;</span></span></p>
<p class=""><span></span><span class="keyword">from</span><span>&nbsp;t_phone_test_10&nbsp;</span><span class="keyword">where</span><span>&nbsp;substr(phone,-1,1)=</span><span class="string">'0'</span><span>;&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test_0;</span><span class="comment">--4816 </span><span>&nbsp;&nbsp;</span></span></p>
<p class="alt"><span>&nbsp;&nbsp;</span></p>
<p class=""><span>8.交换分区&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">alter</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test&nbsp;exchange&nbsp;partition&nbsp;p0&nbsp;</span><span class="keyword">with</span><span>&nbsp;</span><span class="keyword">table</span><span>&nbsp;t_phone_test_0;&nbsp;&nbsp;&nbsp;&nbsp;</span></span></p>
<p class=""><span>&nbsp;&nbsp;</span></p>
<p class="alt"><span></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test&nbsp;partition(p0);</span><span class="comment">--4816&nbsp;</span><span>&nbsp;&nbsp;<br /></span><span class="keyword">select</span><span>&nbsp;</span><span class="func">count</span><span>(*)&nbsp;</span><span class="keyword">from</span><span>&nbsp;t_phone_test_0;</span><span class="comment">--0</span><span>&nbsp;&nbsp;</span></span></p><img src ="http://www.blogjava.net/tjyhy590/aggbug/413380.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-07 22:31 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/07/413380.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle全局索引和本地索引 </title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/06/413330.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Tue, 06 May 2014 09:29:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/06/413330.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413330.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/06/413330.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413330.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413330.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Oracle数据库中，有两种类型的分区索引，全局索引和本地索引，其中本地索引又可以分为本地前缀索引和本地非前缀索引。下面就分别看看每种类型的索引各自的特点。<br /><br />全局索引以整个表的数据为对象建立索引，索引分区中的索引条目既可能是基于相同的键值但是来自不同的分区，也可能是多个不同键值的组合。<br /><br />全局索引既允许索引分区的键值和表分区键值相同，也可以不相同。全局索引和表之间没有直接的联系，这一点和本地索引不同。<br /><br />SQL&gt; create table orders (<br />&nbsp;&nbsp;&nbsp;&nbsp; order_no&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; number,<br />&nbsp;&nbsp;&nbsp;&nbsp; part_no&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; varchar2(40),<br />&nbsp;&nbsp;&nbsp;&nbsp; ord_date&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; date<br />&nbsp;&nbsp;&nbsp;&nbsp; )<br />&nbsp;&nbsp;&nbsp;&nbsp; partition by range (ord_date)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; (partition Q1 values less than (TO_DATE('01-APR-1999','DD-MON-YYYY')),<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; partition Q2 values less than (TO_DATE('01-JUL-1999','DD-MON-YYYY')),<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; partition Q3 values less than (TO_DATE('01-OCT-1999','DD-MON-YYYY')),<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; partition Q4 values less than (TO_DATE('01-JAN-2000','DD-MON-YYYY'))<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; )<br />&nbsp;&nbsp;&nbsp;&nbsp; ;<br /><br />Table created.<br /><br />SQL&gt; create index orders_global_1_idx<br />&nbsp;&nbsp;&nbsp;&nbsp; on orders(ord_date)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; global partition by range (ord_date)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; (partition GLOBAL1 values less than (TO_DATE('01-APR-1999','DD-MON-YYYY')),<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; partition GLOBAL2 values less than (TO_DATE('01-JUL-1999','DD-MON-YYYY')),<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; partition GLOBAL3 values less than (TO_DATE('01-OCT-1999','DD-MON-YYYY')),<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; partition GLOBAL4 values less than (MAXVALUE)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; )<br />&nbsp;&nbsp;&nbsp;&nbsp; ;<br /><br />Index created.<br /><br />SQL&gt; create index orders_global_2_idx<br />&nbsp;&nbsp;&nbsp;&nbsp; on orders(part_no)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; global partition by range (part_no)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; (partition IND1 values less than (555555),<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; partition IND2 values less than (MAXVALUE)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; )<br />&nbsp;&nbsp;&nbsp;&nbsp; ;<br /><br />Index created.<br /><br />从上面的语句可以看出，全局索引和表没有直接的关联，必须显式的指定maxvalue值。假如表中新加了分区，不会在全局索引中自动增加新的分区，必须手工添加相应的分区。<br /><br />SQL&gt; alter table orders add partition Q5 values less than (TO_DATE('01-APR-2000','DD-MON-YYYY'));<br /><br />Table altered.<br /><br />SQL&gt; select TABLE_NAME, PARTITION_NAME from dba_tab_partitions where table_name='ORDERS';<br /><br />TABLE_NAME&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; PARTITION_NAME<br />------------------------------ ------------------------------<br />ORDERS&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Q1<br />ORDERS&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Q2<br />ORDERS&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Q3<br />ORDERS&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Q4<br />ORDERS&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Q5<br /><br />SQL&gt; select INDEX_NAME, PARTITION_NAME from dba_ind_partitions where index_name=upper('orders_global_1_idx');<br /><br />INDEX_NAME&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; PARTITION_NAME<br />------------------------------ ------------------------------<br />ORDERS_GLOBAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; GLOBAL1<br />ORDERS_GLOBAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; GLOBAL2<br />ORDERS_GLOBAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; GLOBAL3<br />ORDERS_GLOBAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; GLOBAL4<br /><br />使用全局索引，索引键值必须和分区键值相同，这就是所谓的前缀索引。Oracle不支持非前缀的全局分区索引，如果需要建立非前缀分区索引，索引必须建成本地索引。<br /><br />SQL&gt; create index orders_global_2_idx<br />&nbsp; 2&nbsp; on orders(part_no)<br />&nbsp; 3&nbsp;&nbsp; global partition by range (order_no)<br />&nbsp; 4&nbsp;&nbsp;&nbsp; (partition IND1 values less than (555555),<br />&nbsp; 5&nbsp;&nbsp;&nbsp;&nbsp; partition IND2 values less than (MAXVALUE)<br />&nbsp; 6&nbsp;&nbsp;&nbsp; )<br />&nbsp; 7&nbsp; ;<br />&nbsp;global partition by range (order_no)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; *<br />ERROR at line 3:<br />ORA-14038: GLOBAL partitioned index must be prefixed<br /><br />接下来再来看看本地分区。<br /><br />本地索引的分区和其对应的表分区数量相等，因此每个表分区都对应着相应的索引分区。使用本地索引，不需要指定分区范围因为索引对于表而言是本地的，当本地索引创建时，Oracle会自动为表中的每个分区创建独立的索引分区。<br /><br />创建本地索引不必显式的指定maxvalue值，因为为表新添加表分区时，会自动添加相应的索引分区。<br /><br />create index orders_local_1_idx<br />on orders(ord_date)<br />&nbsp;local<br />&nbsp; (partition LOCAL1,<br />&nbsp;&nbsp; partition LOCAL2,<br />&nbsp;&nbsp; partition LOCAL3,<br />&nbsp;&nbsp; partition LOCAL4<br />&nbsp; )<br />;<br /><br />Index created.<br /><br />SQL&gt; select INDEX_NAME, PARTITION_NAME from dba_ind_partitions where index_name=upper('orders_local_1_idx');<br /><br />INDEX_NAME&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; PARTITION_NAME<br />------------------------------ ------------------------------<br />ORDERS_LOCAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL1<br />ORDERS_LOCAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL2<br />ORDERS_LOCAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL3<br />ORDERS_LOCAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL4<br /><br />SQL&gt; alter table orders add partition Q5 values less than (TO_DATE('01-APR-2000','DD-MON-YYYY'));<br /><br />Table altered.<br /><br />SQL&gt; select INDEX_NAME, PARTITION_NAME from dba_ind_partitions where index_name=upper('orders_local_1_idx');<br /><br />INDEX_NAME&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; PARTITION_NAME<br />------------------------------ ------------------------------<br />ORDERS_LOCAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL1<br />ORDERS_LOCAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL2<br />ORDERS_LOCAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL3<br />ORDERS_LOCAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL4<br />ORDERS_LOCAL_1_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Q5<br /><br />这里系统已经自动以和表分区相同的名字自动创建了一个索引分区。同理，删除表分区时相对应的索引分区也自动被删除。<br /><br />本地索引和全局索引还有一个显著的差别，就是上面提到的，本地索引可以创建成本地非前缀型，而全局索引只能是前缀型。<br /><br />SQL&gt; create index orders_local_2_idx<br />&nbsp;&nbsp;&nbsp;&nbsp; on orders(part_no)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; local<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; (partition LOCAL1,<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; partition LOCAL2,<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; partition LOCAL3,<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; partition LOCAL4)<br />&nbsp;&nbsp;&nbsp;&nbsp; ;<br /><br />Index created.<br /><br />SQL&gt; select INDEX_NAME, PARTITION_NAME, HIGH_VALUE from dba_ind_partitions<br />&nbsp;&nbsp;&nbsp;&nbsp; where index_name=upper('orders_local_2_idx');<br /><br />INDEX_NAME&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; PARTITION_NAME&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; HIGH_VALUE<br />------------------------------ ------------------------------ ---------------------------------------------------------<br />ORDERS_LOCAL_2_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TO_DATE(' 1999-04-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', <br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 'NLS_CALENDAR=GREGORIA'<br />ORDERS_LOCAL_2_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TO_DATE(' 1999-07-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', <br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 'NLS_CALENDAR=GREGORIA'<br />ORDERS_LOCAL_2_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TO_DATE(' 1999-10-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 'NLS_CALENDAR=GREGORIA'<br />ORDERS_LOCAL_2_IDX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LOCAL4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TO_DATE(' 2000-01-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 'NLS_CALENDAR=GREGORIA'<br /><br />从上面的输出可以看出，虽然索引的键值是part_no，但索引分区的键值仍然和表的分区键值相同，即ord_date，也即是所谓的非前缀型索引。<br /><br />最后，再引用一个例子说明前缀索引和非前缀索引的应用。<br /><br />假设有一个使用DATE列分区的大表。我们经常使用一个VARCHAR2列(VCOL)进行查询，但这个列并不是表的分区键值。<br /><br />有两种可能的方法来访问VCOL列的数据，一是建立基于VCOL列的本地非前缀索引，<br /><br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; -------&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; -------<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; (10 more&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |<br />Values:&nbsp;&nbsp;&nbsp;&nbsp; A..&nbsp;&nbsp;&nbsp;&nbsp; Z..&nbsp;&nbsp; partitions here)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; A..&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Z.. <br /><br />另一种是建立基于VCOL列的全局索引，<br /><br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; -------&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; -------<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; (10 more&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; |<br />Values:&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; A..&nbsp;&nbsp;&nbsp;&nbsp; D..&nbsp;&nbsp; partitions here)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; T..&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Z.. <br /><br />可以看出，如果能够保证VCOL列值的唯一性，全局索引将会是最好的选择。如果VCOL列值不唯一，就需要在本地非前缀索引的并行查询和全局索引顺序查询以及高昂的维护代价之间做出选择。<!-- Baidu Button BEGIN --><img src ="http://www.blogjava.net/tjyhy590/aggbug/413330.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-06 17:29 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/06/413330.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>解决ORA-12560: TNS: 协议适配器错误</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/05/413255.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Mon, 05 May 2014 02:46:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/05/413255.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413255.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/05/413255.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413255.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413255.html</trackback:ping><description><![CDATA[造成ORA-12560: TNS: 协议适配器错误的问题的原因可能有如下三个：<br />1.监听服务没有起起来。windows平台个一如下操作：开始---程序---管理工具---服务，打开服务面板，<br /><br />启动<a class="relatedlink" href="http://www.itpub.net/tree/index_1/" target="_blank">oracle</a>home92TNSlistener服务。<br />2.database instance没有起起来。windows平台如下操作：开始---程序---管理工具---服务，打开服务<br /><br />面板，启动oracleserviceXXXX,XXXX就是你的database SID.<br />3.注册表问题。regedit，然后进入HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0将该环境变量ORACLE_SI<br /><br />D设置为XXXX,XXXX就是你的database SID.或者右几我的电脑，属性--高级--环境变量---系统变量--新建<br /><br />，变量名=oracle_sid,变量值=XXXX,XXXX就是你的database SID.或者进入sqlplus前，在command line下<br /><br />输set oracle_sid=XXXX,XXXX就是你的database SID.<br />经过以上步骤，就可以解决问题。<br /><img src ="http://www.blogjava.net/tjyhy590/aggbug/413255.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-05 10:46 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/05/413255.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle优化全攻略一（Oracle SQL Hint） </title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/04/413241.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Sun, 04 May 2014 13:21:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/04/413241.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413241.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/04/413241.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413241.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413241.html</trackback:ping><description><![CDATA[<div class="blog_content" id="blog_content">其实Oracle的优化器有两种优化方式, <br />基于规则的优化方式(Rule-Based Optimization，简称为RBO) <br />基于代价的优化方式(Cost-Based Optimization，简称为CBO) <br />所以hint也不例外，除了/*+rule*/其他的都是CBO优化方式 <br />RBO方式： <br />&nbsp; 优化器在分析SQL语句时,所遵循的是Oracle内部预定的一些规则。比如我们常见的，当一个where子句中的一列有索引时去走索引。 <br />CBO方式： <br />&nbsp;&nbsp; 它是看语句的代价(Cost),这里的代价主要指Cpu和内存。优化器在判断是否用这种方式时,主要参照的是表及索引的统计信息。统计信息给出表的大小、有少行、每行的长度等信息。这些统计信息起初在库内是没有的，是做analyze后才出现的，很多的时侯过期统计信息会令优化器做出一个错误的执行计划,因些应及时更新这些信息。 <br /><br />优化模式包括Rule、Choose、First rows、All rows四种方式： <br /><br />&nbsp;&nbsp;&nbsp; Rule：基于规则的方式。 <br /><br />&nbsp;&nbsp;&nbsp; Choolse：默认的情况下Oracle用的便是这种方式。指的是当一个表或或索引有统计信息，则走CBO的方式，如果表或索引没统计信息，表又不是特别的小，而且相应的列有索引时，那么就走索引，走RBO的方式。 <br /><br />&nbsp;&nbsp;&nbsp; First Rows：它与Choose方式是类似的，所不同的是当一个表有统计信息时，它将是以最快的方式返回查询的最先的几行，从总体上减少了响应时间。 <br /><br />&nbsp;&nbsp;&nbsp; All Rows:也就是我们所说的Cost的方式，当一个表有统计信息时，它将以最快的方式返回表的所有的行，从总体上提高查询的吞吐量。没有统计信息则走RBO的方式 <br /><br />Oracle在那配置默认的优化规则 <br />&nbsp;&nbsp;&nbsp; A、Instance级别我们可以通过在initSID.ora文件中设定OPTIMIZER_MODE=RULE/CHOOSE/FIRST_ROWS/ALL_ROWS如果没设定OPTIMIZER_MODE参数则默认用的是Choose方式。 <br />&nbsp;&nbsp;&nbsp; B、Sessions级别通过ALTER SESSION SET OPTIMIZER_MODE=RULE/CHOOSE/FIRST_ROWS/ALL_ROWS来设定。 <br />&nbsp;&nbsp;&nbsp; C、语句级别用Hint（/*+ ... */）来设定 <br />为什么表的某个字段明明有索引，但执行计划却不走索引？ <br />&nbsp;&nbsp;&nbsp; 1、优化模式是all_rows的方式 <br />&nbsp;&nbsp;&nbsp; 2、表作过analyze，有统计信息 <br />&nbsp;&nbsp;&nbsp; 3、表很小，Oracle的优化器认为不值得走索引。 <br />提示 <br />&nbsp;&nbsp; 不区分大小写, 多个提示用空格分开 <br />&nbsp; 如：select /*+ hint1(tab1) hint2(TAB1 idx1) */ col1, col2 from tab1 where col1='xxx'; <br />&nbsp; 如果表使用了别名, 那么提示里也必须使用别名 <br />如：select /*+ hint1(t1) */ col1, col2 from tab1 t1 where col1='xxx'; <br />如果使用同一个表的多个用,号分开 <br />如： select /*+ index(t1.A,t1.B) */ col1, col2 <br />&nbsp;&nbsp;&nbsp; from&nbsp;&nbsp; tab1 t1 <br />&nbsp;&nbsp;&nbsp; where&nbsp; col1='xxx'; <br /><br />oracle 10g hints知识, <br />&nbsp;&nbsp;&nbsp; 10g数据库可以使用更多新的optimizer hints来控制优化行为。现在让我们快速解析一下这些强大的新hints： <br /><br />1、spread_min_analysis <br /><br />&nbsp;&nbsp; 使用这一hint，你可以忽略一些关于如详细的关系依赖图分析等电子表格的编译时间优化规则。其他的一些优化，如创建过滤以有选择性的定位电子表格访问结构并限制修订规则等，得到了继续使用。 <br /><br />&nbsp;&nbsp; 由于在规则数非常大的情况下，电子表格分析会很长。这一提示可以帮助我们减少由此产生的数以百小时计的编译时间。 <br /><br />例： <br />&nbsp;&nbsp;&nbsp; SELECT /*+ SPREAD_MIN_ANALYSIS */ ... <br /><br />2、spread_no_analysis <br /><br />&nbsp;&nbsp; 通过这一hint，可以使无电子表格分析成为可能。同样，使用这一hint可以忽略修订规则和过滤产生。如果存在一电子表格分析，编译时间可以被减少到最低程度。 <br /><br />例： <br />&nbsp;&nbsp;&nbsp; SELECT /*+ SPREAD_NO_ANALYSIS */ ... <br /><br />3、use_nl_with_index <br /><br />&nbsp;&nbsp; 这项hint使CBO通过嵌套循环把特定的表格加入到另一原始行。只有在以下情况中，它才使用特定表格作为内部表格：如果没有指定标签，CBO必须可以使用一些标签，且这些标签至少有一个作为索引键值加入判断；反之，CBO必须能够使用至少有一个作为索引键值加入判断的标签。 <br /><br />例： <br />&nbsp; SELECT /*+ USE_NL_WITH_INDEX (polrecpolrind) */ ... <br /><br />4、CARDINALITY <br /><br />&nbsp; 此hint定义了对由查询或查询部分返回的基数的评价。注意如果没有定义表格，基数是由整个查询所返回的总行数。 <br /><br />例： <br />&nbsp; SELECT /*+ CARDINALITY ( [tablespec] card ) */ <br /><br />5、SELECTIVITY <br /><br />&nbsp; 此hint定义了对查询或查询部分选择性的评价。如果只定义了一个表格，选择性是在所定义表格里满足所有单一表格判断的行部分。如果定义了一系列表格，选择性是指在合并以任何顺序满足所有可用判断的全部表格后，所得结果中的行部分。 <br /><br />例： <br />&nbsp;&nbsp; SELECT /*+ SELECTIVITY ( [tablespec] sel ) */ <br /><br />然而，注意如果hints CARDINALITY 和 SELECTIVITY都定义在同样的一批表格，二者都会被忽略。 <br /><br />6、no_use_nl <br /><br />&nbsp; Hint no_use_nl使CBO执行循环嵌套，通过把指定表格作为内部表格，把每个指定表格连接到另一原始行。通过这一hint，只有hash join和sort-merge joins会为指定表格所考虑。 <br /><br />例： <br />&nbsp;&nbsp; SELECT /*+ NO_USE_NL ( employees ) */ ... <br /><br />7、no_use_merge <br /><br />&nbsp; 此hint使CBO通过把指定表格作为内部表格的方式，拒绝sort-merge把每个指定表格加入到另一原始行。 <br /><br />例： <br />&nbsp; SELECT /*+ NO_USE_MERGE ( employees dept ) */ ... <br /><br />8、no_use_hash <br /><br />&nbsp; 此hint使CBO通过把指定表格作为内部表格的方式，拒绝hash joins把每个指定表格加入到另一原始行。 <br /><br />例： <br />&nbsp; SELECT /*+ NO_USE_HASH ( employees dept ) */ ... <br /><br />9、no_index_ffs <br /><br />&nbsp; 此hint使CBO拒绝对指定表格的指定标签进行fast full-index scan。 <br />Syntax: /*+ NO_INDEX_FFS ( tablespecindexspec ) */ <br /><br /><br />在SQL优化过程中常见HINT的用法(前10个比较常用, 前3个最常用)： <br /><br />1. /*+ INDEX */ 和 /*+ INDEX(TABLE INDEX1, index2) */ 和 /*+ INDEX(tab1.col1 tab2.col2) */ 和 /*+ NO_INDEX */ 和 /*+ NO_INDEX(TABLE INDEX1, index2) */ <br /><br />表明对表选择索引的扫描方法. 第一种不指定索引名是让oracle对表中可用索引比较并选择某个最佳索引; 第二种是指定索引名且可指定多个索引; 第三种是10g开始有的, 指定列名, 且表名可不用别名; 第四种即全表扫描; 第五种表示禁用某个索引, 特别适合于准备删除某个索引前的评估操作. 如果同时使用了INDEX和NO_INDEX则两个提示都会被忽略掉. <br />例如:SELECT /*+ INDEX(BSEMPMS SEX_INDEX) USE SEX_INDEX BECAUSE THERE ARE FEWMALE BSEMPMS */ FROM BSEMPMS WHERE SEX='M'; <br /><br />2. /*+ ORDERED */ <br />FROM子句中默认最后一个表是驱动表,ORDERED将from子句中第一个表作为驱动表. 特别适合于多表连接非常慢时尝试. <br />例如:SELECT /*+ ORDERED */ A.COL1,B.COL2,C.COL3 FROM TABLE1 A,TABLE2 B,TABLE3 C WHERE A.COL1=B.COL1 AND B.COL1=C.COL1; <br /><br />3. /*+ PARALLEL(table1,DEGREE) */ 和 /*+ NO_PARALLEL(table1) */ <br />该提示会将需要执行全表扫描的查询分成多个部分（并行度）执行, 然后在不同的操作系统进程中处理每个部分. 该提示还可用于DML语句. 如果SQL里还有排序操作, 进程数会翻倍,此外还有一个一个负责组合这些部分的进程,如下面的例子会产生9个进程. 如果在提示中没有指定DEGREE, 那么就会使用创建表时的默认值. 该提示在默认情况下会使用APPEND提示. NO_PARALLEL是禁止并行操作,否则语句会使用由于定义了并行对象而产生的并行处理. <br />例如:select /*+ PARALLEL(tab_test,4) */ col1, col2 from tab_test order by col2; <br /><br />4. /*+ FIRST_ROWS */ 和 /*+ FIRST_ROWS(n) */ <br />表示用最快速度获得第1/n行, 获得最佳响应时间, 使资源消耗最小化. <br />在update和delete语句里会被忽略, 使用分组语句如group by/distinct/intersect/minus/union时也会被忽略. <br />例如:SELECT /*+ FIRST_ROWS */ EMP_NO,EMP_NAM,DAT_IN FROM BSEMPMS WHERE EMP_NO='SCOTT'; <br /><br />5. /*+ RULE */ <br />表明对语句块选择基于规则的优化方法. <br />例如:SELECT /*+ RULE */ EMP_NO,EMP_NAM,DAT_IN FROM BSEMPMS WHERE EMP_NO='SCOTT'; <br /><br />6. /*+ FULL(TABLE) */ <br />表明对表选择全局扫描的方法. <br />例如:SELECT /*+ FULL(A) */ EMP_NO,EMP_NAM FROM BSEMPMS A WHERE EMP_NO='SCOTT'; <br /><br />7. /*+ LEADING(TABLE) */ <br />类似于ORDERED提示, 将指定的表作为连接次序中的驱动表. <br /><br />8. /*+ USE_NL(TABLE1,TABLE2) */ <br />将指定表与嵌套的连接的行源进行连接,以最快速度返回第一行再连接,与USE_MERGE刚好相反. <br />例如:SELECT /*+ ORDERED USE_NL(BSEMPMS) */ BSDPTMS.DPT_NO,BSEMPMS.EMP_NO,BSEMPMS.EMP_NAM FROM BSEMPMS,BSDPTMS WHERE BSEMPMS.DPT_NO=BSDPTMS.DPT_NO; <br /><br />9. /*+ APPEND */ 和 /*+ NOAPPEND */ <br />直接插入到表的最后,该提示不会检查当前是否有插入操作所需的块空间而是直接添加到新块中, 所以可以提高速度. 当然也会浪费些空间, 因为它不会使用那些做了delete操作的块空间. NOAPPEND提示则相反,所以会取消PARALLEL提示的默认APPEND提示. <br />例如:insert /*+ append */ into test1 select * from test4; <br />insert /*+ parallel(test1) noappend */ into test1 select * from test4; <br /><br />10. /*+ USE_HASH(TABLE1,table2) */ <br />将指定的表与其它行源通过哈希连接方式连接起来.为较大的结果集提供最佳响应时间. 类似于在连接表的结果中遍历每个表上每个结果的嵌套循环, 指定的hash表将被放入内存, 所以需要有足够的内存（hash_area_size或pga_aggregate_target）才能保证语句正确执行, 否则将在磁盘里进行. <br />例如:SELECT /*+ USE_HASH(BSEMPMS,BSDPTMS) */ * FROM BSEMPMS,BSDPTMS WHERE BSEMPMS.DPT_NO=BSDPTMS.DPT_NO; <br /><br />--------------------------------------------------------------------- <br /><br />11. /*+ USE_MERGE(TABLE) */ <br />将指定的表与其它行源通过合并排序连接方式连接起来.特别适合于那种在多个表大量行上进行集合操作的查询, 它会将指定表检索到的的所有行排序后再被合并, 与USE_NL刚好相反. <br />例如:SELECT /*+ USE_MERGE(BSEMPMS,BSDPTMS) */ * FROM BSEMPMS,BSDPTMS WHERE BSEMPMS.DPT_NO=BSDPTMS.DPT_NO; <br /><br />12. /*+ ALL_ROWS */ <br />表明对语句块选择基于开销的优化方法,并获得最佳吞吐量,使资源消耗最小化. 可能会限制某些索引的使用. <br />例如:SELECT /*+ ALL+_ROWS */ EMP_NO,EMP_NAM,DAT_IN FROM BSEMPMS WHERE EMP_NO='SCOTT'; <br /><br />13. /*+ CLUSTER(TABLE) */ <br />提示明确表明对指定表选择簇扫描的访问方法. 如果经常访问连接表但很少修改它, 那就使用集群提示. <br />例如:SELECT /*+ CLUSTER */ BSEMPMS.EMP_NO,DPT_NO FROM BSEMPMS,BSDPTMS WHERE DPT_NO='TEC304' AND BSEMPMS.DPT_NO=BSDPTMS.DPT_NO; <br /><br />14. /*+ INDEX_ASC(TABLE INDEX1, INDEX2) */ <br />表明对表选择索引升序的扫描方法. 从8i开始, 这个提示和INDEX提示功能一样, 因为默认oracle就是按照升序扫描索引的, 除非未来oracle还推出降序扫描索引. <br />例如:SELECT /*+ INDEX_ASC(BSEMPMS PK_BSEMPMS) */ FROM BSEMPMS WHERE DPT_NO='SCOTT'; <br /><br />15. /*+ INDEX_COMBINE(TABLE INDEX1, INDEX2) */ <br />指定多个位图索引, 对于B树索引则使用INDEX这个提示,如果INDEX_COMBINE中没有提供作为参数的索引,将选择出位图索引的布尔组合方式. <br />例如:SELECT /*+ INDEX_COMBINE(BSEMPMS SAL_BMI HIREDATE_BMI) */ * FROM BSEMPMS WHERE SAL&lt;5000000 AND HIREDATE&lt;SYSDATE; <br /><br />16. /*+ INDEX_JOIN(TABLE INDEX1, INDEX2) */ <br />合并索引, 所有数据都已经包含在这两个索引里, 不会再去访问表, 比使用索引并通过rowid去扫描表要快5倍. <br />例如:SELECT /*+ INDEX_JOIN(BSEMPMS SAL_HMI HIREDATE_BMI) */ SAL,HIREDATE FROM BSEMPMS WHERE SAL&lt;60000; <br /><br />17. /*+ INDEX_DESC(TABLE INDEX1, INDEX2) */ <br />表明对表选择索引降序的扫描方法. <br />例如:SELECT /*+ INDEX_DESC(BSEMPMS PK_BSEMPMS) */ FROM BSEMPMS WHERE DPT_NO='SCOTT'; <br /><br />18. /*+ INDEX_FFS(TABLE INDEX_NAME) */ <br />对指定的表执行快速全索引扫描,而不是全表扫描的办法.要求要检索的列都在索引里, 如果表有很多列时特别适用该提示. <br />例如:SELECT /*+ INDEX_FFS(BSEMPMS IN_EMPNAM) */ * FROM BSEMPMS WHERE DPT_NO='TEC305'; <br /><br />19. /*+ NO_EXPAND */ <br />对于WHERE后面的OR 或者IN-LIST的查询语句,NO_EXPAND将阻止其基于优化器对其进行扩展, 缩短解析时间. <br />例如:SELECT /*+ NO_EXPAND */ * FROM BSEMPMS WHERE DPT_NO='TDC506' AND SEX='M'; <br /><br />20. /*+ DRIVING_SITE(TABLE) */ <br />强制与ORACLE所选择的位置不同的表进行查询执行.特别适用于通过dblink连接的远程表. <br />例如:SELECT /*+ DRIVING_SITE(DEPT) */ * FROM BSEMPMS,DEPT@BSDPTMS DEPT WHERE BSEMPMS.DPT_NO=DEPT.DPT_NO; <br /><br />21. /*+ CACHE(TABLE) */ 和 /*+ NOCACHE(TABLE) */ <br />当进行全表扫描时,CACHE提示能够将表全部缓存到内存中,这样访问同一个表的用户可直接在内存中查找数据. 比较适合数据量小但常被访问的表, 也可以建表时指定cache选项这样在第一次访问时就可以对其缓存. NOCACHE则表示对已经指定了CACHE选项的表不进行缓存. <br />例如:SELECT /*+ FULL(BSEMPMS) CAHE(BSEMPMS) */ EMP_NAM FROM BSEMPMS; <br /><br />22. /*+ PUSH_SUBQ */ <br />当SQL里用到了子查询且返回相对少的行时, 该提示可以尽可能早对子查询进行评估从而改善性能, 不适用于合并连接或带远程表的连接. <br />例如:select /*+ PUSH_SUBQ */ emp.empno, emp.ename, itemno from emp, orders where emp.empno = orders.empno and emp.deptno = (select deptno from dept where loc='XXX'); <br />远程连接其他数据库，注意判断数据库是否启动，或者是否有需要的表，否则会出错 <br /><br />23. /*+ INDEX_SS(TABLE INDEX1,INDEX2) */ <br />指示对特定表的索引使用跳跃扫描, 即当组合索引的第一列不在where子句中时, 让其使用该索引 <br />参考资料 <br />Oracle SQL hints <br />&nbsp; /*+ hint */ <br />/*+ hint(argument) */ <br />/*+ hint(argument-1 argument-2) */ <br />All hints except /*+ rule */ cause the CBO to be used. Therefore, it is good practise to analyze the underlying tables if hints are used (or the query is fully hinted. There should be no schema names in hints. Hints must use aliases if alias names are used for table names. So the following is wrong: <br />select /*+ index(scott.emp ix_emp) */ from scott.emp emp_alias <br />better: <br />select /*+ index(emp_alias ix_emp) */ ... from scott.emp emp_alias <br />Why using hints <br />It is a perfect valid question to ask why hints should be used. Oracle comes with an optimizer that promises to optimize a query's execution plan. When this optimizer is really doing a good job, no hints should be required at all. Sometimes, however, the characteristics of the data in the database are changing rapidly, so that the optimizer (or more accuratly, its statistics) are out of date. In this case, a hint could help. It must also be noted, that Oracle allows to lock the statistics when they look ideal which should make the hints meaningless again. <br />Hint categories <br />Hints can be categorized as follows: <br />Hints for Optimization Approaches and Goals, <br />Hints for Access Paths, Hints for Query Transformations, <br />Hints for Join Orders, <br />Hints for Join Operations, <br />Hints for Parallel Execution, <br />Additional Hints <br /><br />Documented Hints <br />Hints for Optimization Approaches and Goals <br />ALL_ROWS <br />One of the hints that 'invokes' the Cost based optimizer <br />ALL_ROWS is usually used for batch processing or data warehousing systems. <br />FIRST_ROWS <br />One of the hints that 'invokes' the Cost based optimizer <br />FIRST_ROWS is usually used for OLTP systems. <br />CHOOSE <br />One of the hints that 'invokes' the Cost based optimizer <br />This hint lets the server choose (between ALL_ROWS and FIRST_ROWS, based on statistics gathered. <br />RULE <br />The RULE hint should be considered deprecated as it is dropped from Oracle9i2. <br />See also the following initialization parameters: optimizer_mode, optimizer_max_permutations, optimizer_index_cost_adj, optimizer_index_caching and <br />Hints for Access Paths <br />CLUSTER <br />Performs a nested loop by the cluster index of one of the tables. <br />FULL <br />Performs full table scan. <br />HASH <br />Hashes one table (full scan) and creates a hash index for that table. Then hashes other table and uses hash index to find corresponding records. Therefore not suitable for &lt; or &gt; join conditions. <br />ROWID <br />Retrieves the row by rowid <br />INDEX <br />Specifying that index index_name should be used on table tab_name: /*+ index (tab_name index_name) */ <br />Specifying that the index should be used the the CBO thinks is most suitable. (Not always a good choice). <br />Starting with Oracle 10g, the index hint can be described: /*+ index(my_tab my_tab(col_1, col_2)) */. Using the index on my_tab that starts with the columns col_1 and col_2. <br />INDEX_ASC <br />INDEX_COMBINE <br />INDEX_DESC <br />INDEX_FFS <br />INDEX_JOIN <br />NO_INDEX <br />AND_EQUAL <br />The AND_EQUAL hint explicitly chooses an execution plan that uses an access path that merges the scans on several single-column indexes <br /><br />Hints for Query Transformations <br />FACT <br />The FACT hint is used in the context of the star transformation to indicate to the transformation that the hinted table should be considered as a fact table. <br />MERGE <br />NO_EXPAND <br />NO_EXPAND_GSET_TO_UNION <br />NO_FACT <br />NO_MERGE <br />NOREWRITE <br />REWRITE <br />STAR_TRANSFORMATION <br />USE_CONCAT <br /><br />Hints for Join Operations <br />DRIVING_SITE <br />HASH_AJ <br />HASH_SJ <br />LEADING <br />MERGE_AJ <br />MERGE_SJ <br />NL_AJ <br />NL_SJ <br />USE_HASH <br />USE_MERGE <br />USE_NL <br /><br />Hints for Parallel Execution <br />NOPARALLEL <br />PARALLEL <br />NOPARALLEL_INDEX <br />PARALLEL_INDEX <br />PQ_DISTRIBUTE <br /><br />Additional Hints <br />ANTIJOIN <br />APPEND <br />If a table or an index is specified with nologging, this hint applied with an insert statement produces a direct path insert which reduces generation of redo. <br />BITMAP <br />BUFFER <br />CACHE <br />CARDINALITY <br />CPU_COSTING <br />DYNAMIC_SAMPLING <br />INLINE <br />MATERIALIZE <br />NO_ACCESS <br />NO_BUFFER <br />NO_MONITORING <br />NO_PUSH_PRED <br />NO_PUSH_SUBQ <br />NO_QKN_BUFF <br />NO_SEMIJOIN <br />NOAPPEND <br />NOCACHE <br />OR_EXPAND <br />ORDERED <br />ORDERED_PREDICATES <br />PUSH_PRED <br />PUSH_SUBQ <br />QB_NAME <br />RESULT_CACHE (Oracle 11g) <br />SELECTIVITY <br />SEMIJOIN <br />SEMIJOIN_DRIVER <br />STAR <br />The STAR hint forces a star query plan to be used, if possible. A star plan has the largest table in the query last in the join order and joins it with a nested loops join on a concatenated index. The STAR hint applies when there are at least three tables, the large table's concatenated index has at least three columns, and there are no conflicting access or join method hints. The optimizer also considers different permutations of the small tables. <br />SWAP_JOIN_INPUTS <br />USE_ANTI <br />USE_SEMI <br /><br />Undocumented hints: <br />BYPASS_RECURSIVE_CHECK <br />Workaraound for bug 1816154 <br />BYPASS_UJVC <br />CACHE_CB <br />CACHE_TEMP_TABLE <br />CIV_GB <br />COLLECTIONS_GET_REFS <br />CUBE_GB <br />CURSOR_SHARING_EXACT <br />DEREF_NO_REWRITE <br />DML_UPDATE <br />DOMAIN_INDEX_NO_SORT <br />DOMAIN_INDEX_SORT <br />DYNAMIC_SAMPLING <br />DYNAMIC_SAMPLING_EST_CDN <br />EXPAND_GSET_TO_UNION <br />FORCE_SAMPLE_BLOCK <br />GBY_CONC_ROLLUP <br />GLOBAL_TABLE_HINTS <br />HWM_BROKERED <br />IGNORE_ON_CLAUSE <br />IGNORE_WHERE_CLAUSE <br />INDEX_RRS <br />INDEX_SS <br />INDEX_SS_ASC <br />INDEX_SS_DESC <br />LIKE_EXPAND <br />LOCAL_INDEXES <br />MV_MERGE <br />NESTED_TABLE_GET_REFS <br />NESTED_TABLE_SET_REFS <br />NESTED_TABLE_SET_SETID <br />NO_FILTERING <br />NO_ORDER_ROLLUPS <br />NO_PRUNE_GSETS <br />NO_STATS_GSETS <br />NO_UNNEST <br />NOCPU_COSTING <br />OVERFLOW_NOMOVE <br />PIV_GB <br />PIV_SSF <br />PQ_MAP <br />PQ_NOMAP <br />REMOTE_MAPPED <br />RESTORE_AS_INTERVALS <br />SAVE_AS_INTERVALS <br />SCN_ASCENDING <br />SKIP_EXT_OPTIMIZER <br />SQLLDR <br />SYS_DL_CURSOR <br />SYS_PARALLEL_TXN <br />SYS_RID_ORDER <br />TIV_GB <br />TIV_SSF <br />UNNEST <br />USE_TTT_FOR_GSETS <br /></div><img src ="http://www.blogjava.net/tjyhy590/aggbug/413241.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-04 21:21 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/04/413241.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle 执行计划（Explain Plan） 说明 </title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/03/413170.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Sat, 03 May 2014 03:52:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/03/413170.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413170.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/03/413170.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413170.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413170.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: &nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 如果要分析某条SQL的性能问题，通常我们要先看SQL的执行计划，看看SQL的每一步执行是否存在问题。 如果一条SQL平时执行的好好的，却有一天突然性能很差，如果排除了系统资源和阻塞的原因，那么基本可以断定是执行计划出了问题。 &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nb...&nbsp;&nbsp;<a href='http://www.blogjava.net/tjyhy590/archive/2014/05/03/413170.html'>阅读全文</a><img src ="http://www.blogjava.net/tjyhy590/aggbug/413170.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-03 11:52 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/03/413170.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>使用EXPLAIN PLAN获取SQL语句执行计划</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/03/413169.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Sat, 03 May 2014 03:44:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/03/413169.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413169.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/03/413169.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413169.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413169.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: SQL查询语句的性能从一定程度上影响整个数据库的性能。很多情况下，数据库性能的低下差不多都是不良SQL语句所引起。而SQL语句的执行计划则决定了SQL语句将会采用何种方式从数据库提取数据并返回给客户端，本文描述的将是如何通过EXPLAIN PLAN 获取SQL语句执行计划来获取SQL语句的执行计划。一、获取SQL语句执行计划的方式&nbsp;&nbsp;&nbsp;&nbsp; 1. 使用expl...&nbsp;&nbsp;<a href='http://www.blogjava.net/tjyhy590/archive/2014/05/03/413169.html'>阅读全文</a><img src ="http://www.blogjava.net/tjyhy590/aggbug/413169.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-03 11:44 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/03/413169.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>执行计划的使用(EXPLAIN)</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/03/413168.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Sat, 03 May 2014 03:36:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/03/413168.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413168.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/03/413168.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413168.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413168.html</trackback:ping><description><![CDATA[对于sql执行的小量高低。我们可以通过执行计划的信息基本上可以进行分析查看该SQL语句执行的时间。连接顺序及浪费的数据库资源等信息，从而判断该SQL语句执行的效率如何，下面就简单的介绍一下执行计划的使用 
<p><strong>　　2.&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Explain使用</strong></p>
<p>　　<a class="channel_keylink" href="http://oracle.chinaitlab.com/" target="_blank">Oracle</a> RDBMS执行每一条SQL语句，都必须经过<a class="channel_keylink" href="http://oracle.chinaitlab.com/" target="_blank">Oracle</a>优化器的评估。所 以，了解优化器是如何选择（搜索）路径以及索引是如何被使用的，对优化SQL语句有很大的帮助。Explain可以用来迅速方便地查出对于给定SQL语句中的查询数据是如何得到的即搜索路径（我们通常称为Access Path）。从而使我们选择最优的查询方式达到最大的优化效果。</p>
<p><strong>　　2.1.&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 安装</strong></p>
<p>　　要使用执行计划首先需要执行相应的脚本。</p>
<p>　　使用Explain工具需要创建Explain_plan表，这必须先进入相关应用表、视图和索引的所有者的帐户内。Oracle的介质中包含有执行此项工作的SQL源程序，例如：</p>
<p>　　ORA_RDBMS： XPLAINPL.SQL （VMS）</p>
<p>　　$ORACLE_HOME/rdbms/admin/utlxplan.sql （UNIX）</p>
<p>　　该脚本后会生成一个表这个程序会创建一个名为plan_table的表，表结构如下：</p>
<p>　　我们简单的介绍一下主要的字段含义：</p>
<p>字段名&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 字段类型&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 含义<br />STATEMENT_ID&nbsp;&nbsp;&nbsp; VARCHAR2(30)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; explain PLAN 语句中所指定的最优STATEMENT_ID 参数值, 如果在EXPLAN PLAN语句中没有使用SET STATEMENT_ID，那么此值会被设为NULL。<br />REMARKS&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; VARCHAR2(80)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 与被解释规划的各步骤相关联的注释最长可达80 字节<br />OPERATION&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; VARCHAR2(30)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 各步骤所执行内部操作的名称在某条语句所产生的第一行中该列的可能取值如下DELETE STATEMENT INSERT STATEMENT SELECT STATEMENT UPDATE STATEMENT<br />OPTIONS&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; VARCHAR2(30)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 对OPERATION 列中所描述操作的变种<br />OBJECT_NODE&nbsp;&nbsp;&nbsp;&nbsp; VARCHAR2(128)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 用于访问对象的数据库链接database link 的名称对于使用并行执行的本地查询该列能够描述操作中输出的次序<br />OBJECT_OWNER&nbsp;&nbsp;&nbsp; VARCHAR2(30)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 对于包含有表或索引的架构schema 给出其所有者的名称<br />OBJECT_NAME&nbsp;&nbsp;&nbsp;&nbsp; VARCHAR2(30)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 表或索引的名称<br />OBJECT_INSTANCE&nbsp; INTEGER&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 根据对象出现在原始original 语句中的次序所给出的相应次序编号就原始的语句文本而论其处理顺序为自左至右自外向内景象扩张view<br />OBJECT_TYPE&nbsp;&nbsp;&nbsp;&nbsp; VARCHAR2(30)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 用于提供对象描述性信息的修饰符例如索引的NON-UNIQUE<br />OPTIMIZER&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; VARCHAR2(255)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 当前优化程序的模式<br />ID&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; INTEGER&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 分配给执行规划各步骤的编号<br />PARENT_ID&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; INTEGER&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 对ID 步骤的输出进行操作的下一个执行步骤的ID<br />POSITION&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; INTEGER&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 对于具有相同PARENT_ID 的步骤其相应的处理次序<br />COST&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; INTEGER&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 根据优化程序的基于开销的方法所估计出的操作开销值对于使用基于规则方法的语句该列为空该列值没有特定的测量单位它只是一个用于比较执行规划开销大小的权重值<br />CARDINALITY&nbsp;&nbsp;&nbsp;&nbsp; INTEGER&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 根据基于开销的方法对操作所访问行数的估计值<br />BYTES&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; INTEGER&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 根据基于开销的方法对操作所访问字节的估计</p>
<p><strong>　　2.2.&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 使用</strong></p>
<p><strong>　　2.2.1.&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 常规使用</strong></p>
<p>　　常规使用语法：</p>
<p>explain PLAN [ SET STATEMENT_ID [=] &lt; string literal &gt; ]<br />[ INTO &lt; table_name &gt; ]<br />FOR &lt; sql_statement &gt;<br />其中：<br />STATEMENT_ID是一个唯一的字符串，把当前执行计划与<a class="channel_keylink" href="http://www.storworld.com/" target="_blank">存储</a>在同一PLAN表中的其它执行计划区别开来。<br />TABLE_NAME是plan表名，它结构如前所示，你可以任意设定这个名称。<br />SQL_STATEMENT是真正的SQL语句。<br />如：<br />SQL&gt; explain plan set statement_id='test1' for<br />&nbsp; 2&nbsp;&nbsp;&nbsp;&nbsp; SELECT a.soctermbegin,<br />&nbsp; 3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; a.soctermend,<br />&nbsp; 4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; a.dealserialno,<br />&nbsp; 5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; a.levydataid,<br />&nbsp; 6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; a.dealtotal,<br />&nbsp; 7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; e.categoryitemcode,<br />&nbsp; 8&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; row_number() over(PARTITION BY a.levydataid ORDER BY 1) AS theRow<br />&nbsp; 9&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; FROM tb_soc_packdealdata&nbsp;&nbsp; a,<br />10&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; tb_Lvy_TaxDataBillMap c,<br />11&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Tb_lvy_BillData&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; d,<br />12&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; tb_soc_levydetaildata e<br />13&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; WHERE a.levydataid = c.datafrompointer(+)<br />14&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; AND c.billdataid = d.billdataid(+)<br />15&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; AND a.levydataid = e.levydataid<br />16&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; AND a.packdealstatuscode = '10'<br />17&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; AND (a.datastatus &lt;&gt; '9' OR a.datastatus is NULL)<br />18&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; AND (d.billstatus IS NULL OR<br />19&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; (d.billstatus &lt;&gt; '2' AND d.billstatus &lt;&gt; '8'))<br />20&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; AND a.Insurcode = '6010952'<br />21&nbsp; ;<br />Explained</p>
<p>　　执行下面语句就可以查看该语句执行的执行计划:</p>
<p>SQL&gt; SELECT A.OPERATION,OPTIONS,OBJECT_NAME,OBJECT_TYPE,ID,PARENT_ID<br />&nbsp; 2&nbsp; FROM PLAN_TABLE&nbsp; a<br />&nbsp; 3&nbsp; WHERE STATEMENT_ID='test1'<br />&nbsp; 4&nbsp; ORDER BY Id;<br />OPERATION&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; OPTIONS&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; OBJECT_NAME&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; OBJECT_TYPEID&nbsp; PARENT_ID<br />---------------- --------------------------------------------- ------------- ----------<br />SELECT STATEMENT&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0<br />WINDOW&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; SORT&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 1&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0<br />FILTER&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 1<br />NESTED LOOPS&nbsp;&nbsp;&nbsp;&nbsp; OUTER&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 2<br />NESTED LOOPS&nbsp;&nbsp;&nbsp;&nbsp; OUTER&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 3<br />NESTED LOOPS&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 4<br />TABLE ACCESS&nbsp;&nbsp;&nbsp;&nbsp; FULL&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TB_SOC_PACKDEALDATA&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 5<br />TABLE ACCESS&nbsp;&nbsp;&nbsp;&nbsp; BY INDEX ROWID TB_SOC_LEVYDETAILDATA&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 5<br />INDEX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; RANGE SCAN&nbsp;&nbsp;&nbsp;&nbsp; IND_DATAID_LEVSOC&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; NON-UNIQUE&nbsp; 8&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 7<br />TABLE ACCESS&nbsp;&nbsp;&nbsp;&nbsp; BY INDEX ROWID TB_LVY_TAXDATABILLMAP&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 9&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 4<br />INDEX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; RANGE SCAN&nbsp;&nbsp;&nbsp;&nbsp; TBLVYTAXDATABIL_DATAFROMPOINTE NON-UNIQUE 10&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 9<br />TABLE ACCESS&nbsp;&nbsp;&nbsp;&nbsp; BY INDEX ROWID TB_LVY_BILLDATA&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 11&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 3<br />INDEX&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; UNIQUE SCAN&nbsp;&nbsp;&nbsp; TBLVYBILLDATA_BILLDATAID&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; UNIQUE<br /><br />　　<strong>2.2.2.&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 自动显示使用</strong><br /><br />　　在SQLPLUS中自动跟踪显示执行计划及相关信息<br />　　SQL&gt;set timing on&nbsp; --显示执行时间<br />　　SQL&gt;set autorace on ?C显示执行计划<br />　　SQL&gt;set autorace on ?C显示执行计划<br />　　SQL&gt;set autotrace traceonly ?C只显示执行计划即不显示查询出来的数据</p>
<p>　　设置完毕后执行SQL语句就会显示执行计划信息及相应的统计信息(需要设置显示该选项)</p>
<p>SQL&gt; select nvl(sum(t.taxdue), 0)<br />&nbsp; 2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; from tb_lvy_sbzs100 t, tb_lvy_declaredoc a, tb_lvy_declaredoc b<br />&nbsp; 3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; where a.dossiercode = 'SB02041108'<br />&nbsp; 4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; and a.pages = 123<br />&nbsp; 5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; and a.remarkid = b.remarkid<br />&nbsp; 6&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; AND A.REMARKID IS NOT NULL<br />&nbsp; 7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; and b.declaredocid = t.declaredocid;<br />NVL(SUM(T.TAXDUE),0)<br />--------------------<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br />　　已用时间:&nbsp; 00: 00: 04.07<br />Execution Plan<br />----------------------------------------------------------<br />&nbsp;&nbsp; 0&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; SELECT STATEMENT Optimizer=CHOOSE (Cost=6 Card=1 Bytes=110)<br />&nbsp;&nbsp; 1&nbsp;&nbsp;&nbsp; 0&nbsp;&nbsp; SORT (AGGREGATE)<br />&nbsp;&nbsp; 2&nbsp;&nbsp;&nbsp; 1&nbsp;&nbsp;&nbsp;&nbsp; NESTED LOOPS (Cost=6 Card=1 Bytes=110)<br />&nbsp;&nbsp; 3&nbsp;&nbsp;&nbsp; 2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; MERGE JOIN (CARTESIAN) (Cost=4 Card=1 Bytes=74)<br />&nbsp;&nbsp; 4&nbsp;&nbsp;&nbsp; 3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TABLE ACCESS (FULL) OF 'TB_LVY_SBZS100' (Cost=2 Card =1 Bytes=31)<br />&nbsp;&nbsp; 5&nbsp;&nbsp;&nbsp; 3&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; BUFFER (SORT) (Cost=2 Card=1 Bytes=43)<br />&nbsp;&nbsp; 6&nbsp;&nbsp;&nbsp; 5&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TABLE ACCESS (FULL) OF 'TB_LVY_DECLAREDOC' (Cost=2 Card=1 Bytes=43)<br />&nbsp;&nbsp; 7&nbsp;&nbsp;&nbsp; 2&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TABLE ACCESS (BY INDEX ROWID) OF 'TB_LVY_DECLAREDOC' (Cost=2 Card=1 Bytes=36)<br />&nbsp;&nbsp; 8&nbsp;&nbsp;&nbsp; 7&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; INDEX (UNIQUE SCAN) OF 'TBLVYDECLAREDOC_DECLAREDOCID' (UNIQUE)<br />Statistics<br />----------------------------------------------------------<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0&nbsp; recursive calls --循环递归次数<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0&nbsp; db block gets&#8213;请求的数据块在buffer能满足的个数<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 6675&nbsp; consistent gets --逻辑IO用于读表并计算行数, 数据请求总数在回滚段Buffer中<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 45&nbsp; physical reads ?C从磁盘读到Buffer Cache数据块数量<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0&nbsp; redo size ?C产生的redo日志大小<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 217&nbsp; bytes sent via SQL*Net to client<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 276&nbsp; bytes received via SQL*Net from client<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 2&nbsp; SQL*Net roundtrips to/from client<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 1&nbsp; sorts (memory)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 0&nbsp; sorts (disk)<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 1&nbsp; rows processed<br />SQL&gt;</p>
<p>　　如果6675&nbsp; consistent gets --逻辑IO用于读表并计算行数, 数据请求总数在回滚段Buffer中</p>
<p>　　45&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; physical reads ?C从磁盘读到Buffer Cache数据块数量的数值比较小则该语句对对数据库的性能比较高。</p>
<p><strong>　　2.2.3.&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; PL/SQL和TOAD中使用</strong></p>
<p>　　如果在PL/SQL中使用选择要查询语句显示执行计划，则只需要SQL WINDOWS 窗口里面输入要查询的SQL语句，然后选择按键F5或者在菜单TOOLS?D?D&gt;Explain Plan 菜单按键就可以在执行计划窗口查看该语句的执行计划。</p>
<p>　　在TOAD语句中在执行当前的SQL窗口中选择下方的Explain PlanTAB页即可以查看要执行语句的执行计划信息。</p>
<p><strong>　　2.3.&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 限制</strong></p>
<p>　　虽然任何SQL语句都可以用explain解释，但对于没有查询的INSERT，UPDATE，DELETE操作来说，这个工具并没有太大的用处。没有子查询的INSERT操作不会创建执行计划，但没有WHERE子句或子查询的UPDATE和DELETE操作会创建执行计划，因为这些操作必须先找出所要的记录。</p>
<p>　　另外，如果你在SQL语句中使用其它类型如sequence等，explain也能揭示它的用法。</p>
<p>　　explain真正的唯一的限制是用户不能去解释其它用户的表，视图，索引或其它类型，用户必须是所有被解释事物的所有者，如果不是所有者而只有select权限，explain会返回一个错误。</p><img src ="http://www.blogjava.net/tjyhy590/aggbug/413168.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-03 11:36 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/03/413168.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>《Oracle物化视图实战手册》</title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413156.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Fri, 02 May 2014 15:03:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413156.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413156.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413156.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413156.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413156.html</trackback:ping><description><![CDATA[<p style="text-align: center"><strong>《</strong><strong>Oracle</strong><strong>物化视图实战手册》</strong></p>
<p>场合：数据变化小，查询出数据还要2次利用，需要数据双向同步的场合</p>
<p>视图：就是一条sql语句，每次查询时都要重新生成执行计划，重新执行，非常消耗时间，放在内存中一次性的</p>
<p>物化视图：执行sql并保留结果，直接放在数据文件中，不放在内存中方便重用【空间换时间】，不受开关机的影响</p>
<p><strong>1.</strong><strong>创建基表并插入数据</strong></p>
<p>create table sino_person_address </p>
<p>(</p>
<p>iid NUMBER(16) not null,</p>
<p>ipersonid NUMBER(16),</p>
<p>spin NUMBER(16),</p>
<p>dgettime DATE,</p>
<p>sorgcode VARCHAR2(20),</p>
<p>smsgfilename VARCHAR2(20),</p>
<p>ilineno NUMBER(8),</p>
<p>saddress VARCHAR2(60),</p>
<p>szip CHAR(6),</p>
<p>scondition CHAR(1),</p>
<p>itrust NUMBER(1),</p>
<p>stoporgcode VARCHAR2(14),</p>
<p>istate NUMBER(1),</p>
<p>constraint PK_SINO_PERSON_ADDRESS primary key (iid)</p>
<p>);</p>
<p>插入数据(插入自动增长序列号字段的方法)</p>
<p>INSERT 语句插入这个字段值为: 序列号的名称.NEXTVAL,seq_sino_person_address.nextval</p>
<p>insert into sino_person_address values(seq_sino_person_address.nextval,123,to_date('2013-04-08 12:12:12','yyyy-mm-dd hh24:mi:ss'),'110','test_report',111,'beijing </p>
<p>xicheng','100100','1',123,1,'1000',0);</p>
<p>insert into sino_person_address values(seq_sino_person_address.nextval,123,to_date('2013-04-09 12:12:12','yyyy-mm-dd hh24:mi:ss'),'120','test_report2',121,'beijing </p>
<p>xicheng','100200','2',123,1,'1002',2);</p>
<p>insert into sino_person_address values(seq_sino_person_address.nextval,123,to_date('2013-04-10 12:12:12','yyyy-mm-dd hh24:mi:ss'),'130','test_report3',131,'beijing </p>
<p>xicheng','100300','3',123,1,'1003',3);</p>
<p>commit</p>
<p>###################################################################################################</p>
<p><strong>2.</strong><strong>创建物化视图日志</strong></p>
<p>意义：记录基表DML操作的变化，实时刷新物化视图</p>
<p>注：包含所有字段</p>
<p>删除物化视图日志</p>
<p>drop materialized view log on t</p>
<p>创建物化视图日志</p>
<p>create materialized view log on t with sequence,rowid (x,y,z) including new values;</p>
<p>参数说明：</p>
<p>with sequence：以序号增1的方式进行变化记录</p>
<p>rowid (x,y,z)：定位哪些数据发生了变化，日志记录rowid指向的数据块的位置和变化</p>
<p>删除物化视图日志</p>
<p>drop materialized view log on sino_person_address;</p>
<p>基于主键方式的刷新，创建物化视图日志</p>
<p>CREATE MATERIALIZED VIEW LOG ON sino_person_address</p>
<p>WITH PRIMARY KEY</p>
<p>INCLUDING NEW VALUES</p>
<p>【TABLESPACE sinojfs2】; 可选项</p>
<p><strong>3.</strong><strong>创建物化视图</strong></p>
<p>创建物化视图</p>
<p>create materialized view mv_t build immediate refresh fast on commit enable query rewrite as select x,y,z,count(*) from t group by x,y,z;</p>
<p>删除物化视图</p>
<p>drop materialized view mv_sino_person_address;</p>
<p>create materialized view mv_sino_person_address </p>
<p>tablespace SINOJFS2</p>
<p>build immediate 创建物化视图时，立即刷新基表</p>
<p>refresh fast with primary key 支持基于主键的快速刷新（增量刷新），基表必须有主键</p>
<p>on commit 支持commit动作自动刷新</p>
<p>enable query rewrite </p>
<p>as select * from sino_person_address;</p>
<p>create materialized view mv_sino_person_address </p>
<p>tablespace SINOJFS2</p>
<p>build immediate </p>
<p>refresh fast with primary key refresh complete全部刷新【全表刷新】可选项</p>
<p>on demand 支持需求时手工刷新</p>
<p>enable query rewrite</p>
<p>as select * from sino_person_address;</p>
<p>########################################################################################</p>
<p>参数说明：</p>
<p>build immediate：创建物化视图时，立即刷新基表</p>
<p>refresh fast with primary key：支持基于主键的快速刷新（增量刷新），基表必须有主键</p>
<p>on commit：基于commit动作的自动刷新 on demand：基于需求时的手工刷新</p>
<p>enable query rewrite：支持查询重新（使用物化视图代替基表，查询必须重写，查询重写是透明的并且不需要对物化视图有任何权限，物化视图可以启用和禁用查询重写）</p>
<p>查询重写：select * from t基表，执行计划走的是mv_t物化视图，禁用后，执行计划走的就是t基表了</p>
<p>tablespace SINOJFS2 创建于SINOJFS2表空间</p>
<p>(1)创建方式：BUILD IMMEDIATE（立即生成数据）， BUILD DEFERRED（下一次刷新时生新数据）， ON PREBUILD TABLE（不创建新的数据段，用已存在的含有当前物化视图数据的表来代替）； &nbsp; <br />(2)ENABLE | DISABLE QUERY REWRITE指定是否启用当前物化视图用于查询重写，启用该选项时，系统会检查以保证查询的可确定性（不允许有如序列数，USER， DATE等不确定的返回值），DISABLE时物化视图照样可以被刷新； &nbsp; &nbsp;<br />与物化视图生效相关的设置 &nbsp; &nbsp;<br />(1)初始化参数JOB_QUEUE_PROCESSES设置大于零，物化的自动刷新操作需要JOB QUEUE进程来执行； &nbsp; &nbsp;<br />(2)初始化参数OPTIMIZER_MODE要设成某种CBO优化模式； &nbsp; &nbsp;<br />(3)用户会话有QUERY_REWRITE（优化器能将查询重写到本方案物化视图）或GLOBAL_QUERY_REWRITE（优化器能将查询重写到其它方案的物化视图）系统权限； &nbsp; &nbsp;<br />(4)初始化参数QUERY_REWRITE_ENABLED 指示优化器是否动态重写查询来使用物化视图，这个参数可以在四个级别上进行设置（参数文件，ALTER SYSTEM， ALTER SESSION， HINTS）； &nbsp; &nbsp;<br />(5)初始化参数QUERY_REWRITE_INTEGRITY 指示优化器在不同的数据一致性情况下决定是否使用物化视图来重写查询，ENFORCED（只有在能确保数据一致的前提下才使用物化视图）， TRUSTED（数据不一定一致，只要有用维度对象定义的关系存在，就可使用物化视图）， STALE_TOLERATED（数据不一致，也没有相关的维度定义时仍可使用物化视图），这个参数可以在三个级别上进行设置（参数文件，ALTER SYSTEM， ALTER SESSION）；</p>
<p><strong>4. </strong><strong>物化视图</strong><strong>DML</strong><strong>操作测试</strong></p>
<p>（1）验证物化视图是否随记录增加而增加</p>
<p>insert into sino_person_address values(seq_sino_person_address.nextval,123,to_date('2013-04-11 13:13:13','yyyy-mm-dd hh24:mi:ss'),'140','test_report4',141,'beijing </p>
<p>xicheng','100400','4',123,1,'1004',4);</p>
<p>select * from sino_person_address order by dgetdate;</p>
<p>select * from mv_sino_person_address order by dgetdate; 随记录增加而木有刷新，必须commit之后才触发物化视图刷新，没有问题</p>
<p>exec dbms_mview.refresh('mv_sino_person_address','c'); 还可以手动全部刷新【全表刷新】（先清除，再重装数据）</p>
<p>exec dbms_mview.refresh('mv_sino_person_address','f'); 也可以快速刷新【增量刷新】借助物化视图日志，只检查自上次刷新后改变了的数据来进行刷新）</p>
<p>（2）验证物化视图是否随记录删除而减少</p>
<p>delete from sino_person_address where iid=21;</p>
<p>select * from sino_person_address order by dgetdate;</p>
<p>select * from mv_sino_person_address order by dgetdate; 随记录删除而木有刷新，必须commit之后才触发物化视图刷新，没有问题</p>
<p><a></a><a>exec dbms_mview.refresh('mv_sino_person_address','c'); </a>还可以手动全部刷新【全表刷新】（先清除，再重装数据）</p>
<p>exec dbms_mview.refresh('mv_sino_person_address','f'); 也可以快速刷新【增量刷新】借助物化视图日志，只检查自上次刷新后改变了的数据来进行刷新）</p>
<p>（3）验证物化视图是否随记录修改而更新</p>
<p>update sino_person_address set sorgcode='200' where sorgcode='120';</p>
<p>select * from sino_person_address order by dgetdate;</p>
<p>select * from mv_sino_person_address order by dgetdate; 随记录修改而木有刷新，必须commit之后才触发物化视图刷新，没有问题</p>
<p>exec dbms_mview.refresh('mv_sino_person_address','c'); 还可以手动全部刷新【全表刷新】（先清除，再重装数据）</p>
<p>exec dbms_mview.refresh('mv_sino_person_address','f'); 也可以快速刷新【增量刷新】（借助物化视图日志，只检查自上次刷新后改变了的数据来进行刷新）</p>
<p>（4）验证物化视图是否随truncate而清空</p>
<p>truncate table sino_person_address;</p>
<p>select * from sino_person_address order by dgetdate;</p>
<p>select * from mv_sino_person_address order by dgetdate; 随记录truncate而木有清空，必须手动truncate table mv_sino_person_address;才能清空（两者是没有关联的），没有问题</p>
<p><strong>5.</strong><strong>物化视图刷新</strong></p>
<p>根据业务需求，每月定时刷新。根据以上条件，选择使用ORACLE自带工具DBMS_MVIEW工具包中REFRESH方法对物化视图进行刷新。该方法有两个参数，第一个参数是需要刷新的物化视图名称，第二个参数是刷新方式。我们可以写存储过程，对每个物化视图调用一次REFRESH方法，也可以使用&#8220;，&#8221;把物化视图连接以来，一次刷新。</p>
<p>定义存储过程</p>
<p>create or replace procedure pro_mview_refresh</p>
<p>as</p>
<p>begin</p>
<p>dbms_mview.refresh('mv_sino_person_address','f');</p>
<p>end;</p>
<p>/</p>
<p>执行存储过程</p>
<p>execute pro_mview_refresh;</p>
<p>还可以刷新所有物化视图 dbms_mview.refresh_all_mviews;</p>
<p>创建存储过程</p>
<p><a></a><a>drop procedure pro_refresh_all_mviews;</a></p>
<p>create or replace procedure pro_refresh_all_mviews</p>
<p>as</p>
<p>i number;</p>
<p>begin</p>
<p>dbms_mview.refresh_all_mviews(number_of_failures=&gt;i);</p>
<p>dbms_output.put_line('number_of_failures=&gt;'||i);</p>
<p>end;</p>
<p>/</p>
<p>执行</p>
<p><a></a><a>execute</a><a></a><a>pro_refresh_all_mviews</a>;</p>
<p>set serveroutput on;不可放在存储过程中，因为这是sqlplus命令，如果你怕忘记或者嫌麻烦可以把set serveroutput on;</p>
<p>写入/opt/oracle/product/11.2.0/dbhome_1/sqlplus/admin/glogin.sql中，每次使用sqlplus时自动加载这个文件</p>
<p>如果想用PL/SQL Developer工具访问数据库，请在C:\Program Files\PLSQL Developer\Login.sql 文件里添加</p>
<p>-- Autostart Command Window script</p>
<p>set serveroutput on;</p>
<p>这样以后再使用PL/SQL Developer工具访问数据库就可以自动加载这条命令了</p>
<p>###############################################################################################</p>
<p>研发人员专用，手动刷新，想刷就刷</p>
<p>set serveroutput on; 打开屏幕显示功能，就可以看到number_of_failures=&gt;0结果</p>
<p>PL/SQL 匿名块</p>
<p>declare</p>
<p>i number;</p>
<p>begin</p>
<p>dbms_mview.refresh_all_mviews(number_of_failures=&gt;i);</p>
<p>dbms_output.put_line('number_of_failures=&gt;'||i);</p>
<p>end;</p>
<p>/</p>
<p>number_of_failures=&gt;0</p>
<p>Number_of_failures 表示刷新物化视图失败个数</p>
<p>采用默认refresh force 刷新方式：先试图用FAST方式刷新，如果失败再用COMPLETE方式刷新，这是默认的刷新方式</p>
<p>注意:</p>
<p>1、 如果需要同时刷新多个物化视图，必须用逗号把各个物化视图名称连接起来，并对每个视图都要指明刷新方式（f、增量刷新，c、完全刷新，?、强制刷新，从不刷新）。</p>
<p>NEVER REFRESH（不刷新）</p>
<p>REFREST FAST（借助物化视图日志，只检查自上次刷新后改变了的数据来进行刷新）</p>
<p>REFRESH COMPLETE（先清除，再重装数据）</p>
<p>REFRESH FORCE（先试图用FAST方式刷新，如果失败再用COMPLETE方式刷新，这是默认的刷新方式）</p>
<p>确定刷新时机：</p>
<p>ON COMMIT（事务提交时刷新），</p>
<p>ON DEMAND（用DBMS_MVIEW.REFRESH， DBMS_MVIEW.REFRESH_DEPENDENT， DBMS_MVIEW.REFRESH_ALL_MVIEWS来手工刷新），</p>
<p>By Time（用START WITH 和 NEXT 子句创建的job来定时自动刷新）；</p>
<p>[dbms_mview.refresh('mv_sino_person_address,mv_person_address_his','ff');]</p>
<p>2、当日志和物化视图创建好后，删除日志，则需要重新创建物化视图，否则无法增量刷新。</p>
<p>drop materialized view log on sino_person_address; 删除日志</p>
<p>SQL&gt; exec dbms_mview.refresh('mv_sino_person_address','c'); 删除物化视图日志，只可以支持物化视图全部刷新</p>
<p>PL/SQL procedure successfully completed</p>
<p>#################################################################################</p>
<p>SQL&gt; exec dbms_mview.refresh('mv_sino_person_address','f'); 无法增量刷新</p>
<p>begin dbms_mview.refresh('mv_sino_person_address','f'); end;</p>
<p>ORA-23413: 表 "SINOJFS"."SINO_PERSON_ADDRESS" 没有实体化视图日志</p>
<p>ORA-06512: 在 "SYS.DBMS_SNAPSHOT", line 2558</p>
<p>ORA-06512: 在 "SYS.DBMS_SNAPSHOT", line 2771</p>
<p>ORA-06512: 在 "SYS.DBMS_SNAPSHOT", line 2740</p>
<p>ORA-06512: 在 line 2</p>
<p>SQL&gt; create materialized view log on sino_person_employment 重新创建物化视图日志</p>
<p>2 with primary key</p>
<p>3 including new values;</p>
<p>Materialized view log created</p>
<p>SQL&gt; exec dbms_mview.refresh('mv_sino_person_employment','f'); 但还是不支持增量刷新，因为日志内容和原表内容不一致了</p>
<p>begin dbms_mview.refresh('mv_sino_person_employment','f'); end;</p>
<p>ORA-12034: "SINOJFS"."SINO_PERSON_EMPLOYMENT" 上的实体化视图日志比上次刷新后的内容新</p>
<p>ORA-06512: 在 "SYS.DBMS_SNAPSHOT", line 2558</p>
<p>ORA-06512: 在 "SYS.DBMS_SNAPSHOT", line 2771</p>
<p>ORA-06512: 在 "SYS.DBMS_SNAPSHOT", line 2740</p>
<p>ORA-06512: 在 line 2</p>
<p>因为：丢失了删除日志那一点-&gt;重建日志那一点之间的原表DML变化，因此日志内容和原表内容不一致了</p>
<p>解决方案：重建物化视图日志 重新【增量刷新】和【全表刷新】一遍</p>
<p>SQL&gt; drop materialized view log on sino_loan_compact; 删除日志</p>
<p>Materialized view log dropped</p>
<p>SQL&gt; create materialized view log on sino_loan_compact 重建日志</p>
<p>2 with primary key</p>
<p>3 including new values;</p>
<p>Materialized view log created</p>
<p>SQL&gt; exec dbms_mview.refresh('mv_sino_loan_compact','c'); 必须先全表刷新</p>
<p>PL/SQL procedure successfully completed</p>
<p>SQL&gt; exec dbms_mview.refresh('mv_sino_loan_compact','f'); 再增量刷新，否则ORA-12034: "SINOJFS"."SINO_LOAN_COMPACT" 上的实体化视图日志比上次刷新后的内容新</p>
<p>PL/SQL procedure successfully completed</p>
<p>小结：只要能够增量刷新，说明日志没有问题了</p>
<p>简述所有视图的快速刷新和全表刷新命令（测试使用） 10张视图</p>
<p>select owner,table_name,tablespace_name,status from dba_tables where table_name in ('SINO_LOAN_APPLY');</p>
<p>update SINO_LOAN_APPLY set sorgcode ='1000' where iid =858;</p>
<p>exec dbms_mview.refresh('mv_sino_loan_compact','c');</p>
<p>exec dbms_mview.refresh('mv_sino_loan_compact','f');</p>
<p>exec dbms_mview.refresh('mv_sino_loan_apply','c');</p>
<p>exec dbms_mview.refresh('mv_sino_loan_apply','f');</p>
<p>exec dbms_mview.refresh('mv_sino_loan_spec_trade','c');</p>
<p>exec dbms_mview.refresh('mv_sino_loan_spec_trade','f');</p>
<p>exec dbms_mview.refresh('mv_sino_loan','c');</p>
<p>exec dbms_mview.refresh('mv_sino_loan','f');</p>
<p>exec dbms_mview.refresh('mv_sino_loan_guarantee','c');</p>
<p>exec dbms_mview.refresh('mv_sino_loan_guarantee','f');</p>
<p>exec dbms_mview.refresh('mv_sino_loan_investor','c');</p>
<p>exec dbms_mview.refresh('mv_sino_loan_investor','f');</p>
<p>###############################################################################</p>
<p><a></a><a>exec dbms_mview.refresh('mv_sino_person_employment','c');</a></p>
<p>exec dbms_mview.refresh('mv_sino_person_employment','f');</p>
<p>exec dbms_mview.refresh('mv_sino_person_address','c');</p>
<p>exec dbms_mview.refresh('mv_sino_person_address','f');</p>
<p>exec dbms_mview.refresh('mv_sino_person_certification','c');</p>
<p>exec dbms_mview.refresh('mv_sino_person_certification','f');</p>
<p>exec dbms_mview.refresh('mv_sino_person','c');</p>
<p>exec dbms_mview.refresh('mv_sino_person','f');</p>
<p>3.基表增加字段后对应物化视图不能自动同步结构</p>
<p>业务表增加 上报状态 字段 ipbcstate number(1) 可以为空</p>
<p>文档 建模 脚本 物化视图</p>
<p>sino_person_certification 完成 完成 完成 完成</p>
<p>sino_person 完成 完成 完成 完成</p>
<p>sino_person_address 完成 完成 完成 完成</p>
<p>sino_person_employment 完成 完成 完成 完成</p>
<p>sino_person_address_his 完成 完成 完成</p>
<p>sino_person_employment_his 完成 完成 完成</p>
<p>sino_person_his 完成 完成 完成</p>
<p>sino_loan 完成 完成 完成 <a></a><a>完成</a></p>
<p>sino_loan_compact 完成 完成 完成 完成</p>
<p>sino_loan_spec_trade 完成 完成 完成 完成</p>
<p>sino_loan_guarantee 完成 完成 完成 完成</p>
<p>sino_loan_investor 完成 完成 完成 完成</p>
<p>sino_loan_apply 完成 完成 完成 完成</p>
<p>对比IPBCSTATE 字段基表有，但物化视图没有，需要重建物化视图解决</p>
<p>select * from mv_sino_loan_compact where rownum&lt;2;</p>
<p>select * from sino_loan_compact where rownum&lt;2;</p>
<p>select * from mv_sino_loan where rownum &lt; 2;</p>
<p>select * from sino_loan where rownum &lt; 2;</p>
<p><a></a><a>select * from mv_sino_loan_apply where rownum &lt; 2;</a></p>
<p>select * from sino_loan_apply where rownum &lt; 2;</p>
<p><a></a><a>select * from </a>mv_sino_loan_guarantee where rownum &lt; 2;</p>
<p>select * from sino_loan_guarantee where rownum &lt; 2;</p>
<p>select * from mv_sino_loan_guarantee where rownum &lt; 2;</p>
<p>select * from sino_loan_guarantee where rownum &lt; 2;</p>
<p>select * from mv_sino_loan_investor where rownum &lt; 2;</p>
<p>select * from sino_loan_investor where rownum &lt; 2;</p>
<p><a></a><a>select * from </a>mv_sino_loan_spec_trade where rownum &lt; 2;</p>
<p>select * from sino_loan_spec_trade where rownum &lt; 2;</p>
<p>################################################################################</p>
<p>select * from mv_sino_person where rownum &lt; 2;</p>
<p>select * from sino_person where rownum &lt; 2;</p>
<p>select * from mv_sino_person_address where rownum &lt; 2;</p>
<p>select * from sino_person_address where rownum &lt; 2;</p>
<p>select * from mv_sino_person_certification where rownum &lt; 2;</p>
<p>select * from sino_person_certification where rownum &lt; 2;</p>
<p>select * from mv_sino_person_employment where rownum &lt; 2;</p>
<p>select * from sino_person_employment where rownum &lt; 2;</p>
<p>##################################################################################</p>
<p>4.因为上面写的物化视图是基于主键进行刷新的，因此原表必须要有主键</p>
<p><strong>6.</strong><strong>定时刷新</strong><strong>JOB</strong></p>
<p>确定执行时间间隔 &nbsp; <br />1)、 每分钟执行 &nbsp; &nbsp;<br />Interval =&gt; TRUNC(sysdate,'mi') + 1 / (24*60) &nbsp; &nbsp;<br />2)、 每天定时执行 &nbsp; &nbsp;<br />例如：每天下午2点执行一次pro_mview_refresh存储过程 &nbsp; &nbsp;<br />Interval =&gt; TRUNC(sysdate) + 1 +14/ (24) &nbsp; &nbsp;<br />3)、 每周定时执行 &nbsp; &nbsp;<br />例如：每周一凌晨2点执行 &nbsp; &nbsp;<br />Interval =&gt; TRUNC(next_day(sysdate,2))+2/24 --星期一,一周的第二天 &nbsp; &nbsp;<br />4)、 每月定时执行 &nbsp; &nbsp;<br />例如：每月1日凌晨2点执行 &nbsp; &nbsp;<br />Interval =&gt;TRUNC(LAST_DAY(SYSDATE))+1+2/24 &nbsp; &nbsp;<br />5)、 每季度定时执行 &nbsp; &nbsp;<br />例如每季度的第一天凌晨2点执行 &nbsp; &nbsp;<br />Interval =&gt; TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 2/24 &nbsp; &nbsp;<br />6)、 每半年定时执行 &nbsp; &nbsp;<br />例如：每年7月1日和1月1日凌晨2点 &nbsp; &nbsp;<br />Interval =&gt; ADD_MONTHS(trunc(sysdate,'yyyy'),6)+2/24 &nbsp; &nbsp;<br />7)、 每年定时执行 &nbsp; &nbsp;<br />例如：每年1月1日凌晨2点执行 &nbsp; &nbsp;<br />Interval =&gt;ADD_MONTHS(trunc(sysdate,'yyyy'),12)+2/24</p>
<p><strong>通过</strong><strong>jobs</strong><strong>的使用就能实现每天或每月的指定时间执行一个函数、过程与命令</strong></p>
<p>set serveroutput on 启动屏幕输出功能</p>
<p>SQL&gt; execute dbms_output.put_line('This is'); 已经可以正常输出</p>
<p>This is</p>
<p>创建作业</p>
<p>variable job_num number; 定义存储job编号的变量</p>
<p>declare job_num number; pro_refresh_all_mviews</p>
<p>begin</p>
<p>dbms_job.submit</p>
<p>(job=&gt;:job_num,</p>
<p>what=&gt;'pro_refresh_all_mviews;',</p>
<p>next_date=&gt;sysdate,</p>
<p>interval=&gt;'sysdate+1/1440'); 每天1440分钟，每一分钟运行pro_mview_refresh过程一次</p>
<p>dbms_output.put_line('Job Number is'||to_char(job_num));</p>
<p>commit;</p>
<p>end;</p>
<p>/</p>
<p>############################################################################################</p>
<p>绑定变量版，必须先定义变量</p>
<p>variable job_num number;</p>
<p>declare job_num number;</p>
<p>begin</p>
<p>dbms_job.submit</p>
<p>(job=&gt;:job_num,</p>
<p>what=&gt;'pro_refresh_all_mviews;',</p>
<p>next_date=&gt;sysdate,</p>
<p>interval=&gt;'trunc(SYSDATE+5/1440,''MI'')'); 每5分钟运行一次job</p>
<p>dbms_output.put_line('Job Number is'||to_char(job_num));</p>
<p>commit;</p>
<p>end;</p>
<p>/</p>
<p>例如：每天上午10点执行一次pro_refresh_all_mviews存储过程 &nbsp; <br />Interval =&gt; TRUNC(sysdate) + 1 +10/ (24) &nbsp; &nbsp;<br />declare job_num number;</p>
<p>begin</p>
<p>dbms_job.submit</p>
<p>(job=&gt;:job_num,</p>
<p>what=&gt;'pro_refresh_all_mviews;',</p>
<p>next_date=&gt;sysdate,</p>
<p>interval=&gt;'trunc(SYSDATE)+1+10/24'); 每天上午10点运行一次job</p>
<p>dbms_output.put_line('Job Number is'||to_char(job_num));</p>
<p>commit;</p>
<p>end;</p>
<p>/</p>
<p>Job Number is</p>
<p>PL/SQL procedure successfully completed</p>
<p>job_num</p>
<p>---------</p>
<p>1</p>
<p>####################################################################################</p>
<p>PL/SQL 匿名块版，可以直接在块中定义变量，比较方面现在采用这种</p>
<p>declare </p>
<p>job_num number;</p>
<p>begin</p>
<p>dbms_job.submit</p>
<p>(job=&gt;job_num,</p>
<p>what=&gt;'pro_refresh_all_mviews;',</p>
<p>next_date=&gt;sysdate,</p>
<p>interval=&gt;'trunc(SYSDATE)+1+10/24');</p>
<p>dbms_output.put_line('Job Number is '||job_num);</p>
<p>commit;</p>
<p>end;</p>
<p>/</p>
<p>Job Number is 4</p>
<p>PL/SQL procedure successfully completed</p>
<p>####################################################################################</p>
<p>dbms_job.submit( job out binary_integer, &nbsp; <br />what in varchar2, &nbsp; &nbsp;<br />next_date in date， &nbsp; &nbsp;<br />interval in varchar2, &nbsp; &nbsp;<br />no_parse in boolean)</p>
<p>&#9679;job：输出变量，这是作业在作业队列中的编号； &nbsp; <br />&#9679;what：执行作业的存储过程及其输入参数； &nbsp; &nbsp;<br />&#9679;next_date：作业初次执行的时间； &nbsp; &nbsp;<br />&#9679;interval：作业执行的时间间隔。指上一次执行结束到下一次开始执行的时间间隔 &nbsp; &nbsp;<br />其中Interval这个值是决定Job何时，被重新执行的关键；当interval设置为null时，该job执行结束后，就被从队列中删除。假如我们需要该job周期性地执行，则要用&#8216;sysdate＋m&#8217;表示。如何更好地确定执行时间的间隔需要我们掌握一个函数TRUNC。</p>
<p>SQL&gt; show parameter job_queue_process 作业队列进程数，oracle能够并发job数量，0~1000</p>
<p>NAME TYPE VALUE</p>
<p>------------------------------------ ----------- ------------------------------</p>
<p>job_queue_processes integer 1000</p>
<p>Oracle提供的数据字典user_jobs监控作业状态</p>
<p>SQL&gt; select job,log_user,what,last_date,last_sec,next_date,next_sec,failures,broken from user_jobs;</p>
<p>Job 作业唯一编号</p>
<p>Log_user 提交作业的用户</p>
<p>What 作业执行的存储过程</p>
<p>Last_date 最后一次成功运行作业的日期</p>
<p>Last_sec 最后一次成功运行作业的时间</p>
<p>Next_date 下一次运行作业日期</p>
<p>Next_sec 下一次运行作业时间</p>
<p>Failures 执行失败次数，当执行job出现错误时，Oracle将其记录在日志里，失败次数每次自动加1，加到16之后Oracle就不在执行它了</p>
<p>Broken 是否是异常作业，当执行失败次数达到16时，Oracle就将该job标志为broken。此后，Oracle不再继续执行它，直到用户调用过程dbms_job.broken，重新设置为not broken，或强制调用dbms_job.run来重新执行它。Y标示作业中断，以后不会运行，N表示作业正常，可以运行</p>
<p>运行作业 &nbsp; <br />begin &nbsp; &nbsp;<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;dbms_job.run(:job_num); job_num是存储job编号的变量 &nbsp; &nbsp;<br />end; &nbsp; &nbsp;<br />查询作业状态 &nbsp; &nbsp;<br />SQL&gt; select job,log_user,what,last_date,last_sec,next_date,next_sec,failures,broken from user_jobs;</p>
<p>JOB LOG_USER WHAT LAST_DATE LAST_SEC NEXT_DATE NEXT_SEC FAILURES BROKEN</p>
<p>---------- --------- ---------------------------------------------------- ----------- ---------------- ----------- </p>
<p>1 SINOJFS pro_refresh_all_mviews; 2013-4-26 1 11:27:38 2013-4-27 1 10:00:00 0 N</p>
<p>Job 作业唯一编号</p>
<p>Log_user 提交作业的用户</p>
<p>What 作业执行的存储过程</p>
<p>Last_date 最后一次成功运行作业的日期</p>
<p>Last_sec 最后一次成功运行作业的时间</p>
<p>Next_date 下一次运行作业日期</p>
<p>Next_sec 下一次运行作业时间</p>
<p>Failures 执行失败次数，当执行job出现错误时，Oracle将其记录在日志里，失败次数每次自动加1，加到16之后Oracle就不在执行它了</p>
<p>Broken 是否是异常作业，当执行失败次数达到16时，Oracle就将该job标志为broken。此后，Oracle不再继续执行它，直到用户调用过程dbms_job.broken，重新设置为not broken；</p>
<p>或强制调用dbms_job.run来重新执行它。Y标示作业中断，以后不会运行，N表示作业正常，可以运行</p>
<p>删除作业 &nbsp; <br />begin &nbsp; &nbsp;<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;dbms_job.remove(:job_num); &nbsp; &nbsp;<br />end;</p>
<p>修改作业</p>
<p>dbms_job.remove(jobno); 删除job号</p>
<p>例 execute dbms_job.remove(1);</p>
<p>######################################################################</p>
<p>dbms_job.what(jobno,what); 修改执行的存储过程</p>
<p>dbms_job.next_date(job,next_date)修改下次执行的时间</p>
<p>例 exec dbms_job.next_date(46,sysdate+2/(24*60)); 46作业号</p>
<p>#####################################################################</p>
<p>dbms_job.interval(job,interval) &nbsp; :修改间隔时间</p>
<p>例 exec dbms_job.interval(46,sysdate+3/(24*60));</p>
<p>###################################################################### &nbsp; <br />dbms_job.broken(job,true) &nbsp; &nbsp; 中断job </p>
<p>例 exec dbms_job.broken(46,true); 46作业号 exec dbms_job.broken(2,true) BROKEN=Y</p>
<p>#######################################################################</p>
<p>dbms_job.broken(job,false,next_date) &nbsp; next_date:下次执行时间，如果不填则马上启动job</p>
<p>例 exec dbms_job.broken(46,false); 启动job exec dbms_job.broken(2,false); BROKEN=N</p>
<p>########################################################################</p>
<p>dbms_job.run(jobno); 运行作业</p>
<p>例子 execute dbms_job.run(1);</p><img src ="http://www.blogjava.net/tjyhy590/aggbug/413156.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-02 23:03 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/02/413156.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle 物化视图 说明 </title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413155.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Fri, 02 May 2014 15:02:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413155.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413155.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413155.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413155.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413155.html</trackback:ping><description><![CDATA[<h2 sizset="75" sizcache="28"><a name="t0"></a><span style="color: red">一．&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: red">物化视图概述</span></h2>
<p><span style="white-space: pre"></span>Oracle的物化视图是包括一个查询结果的数据库对像，它是远程数据的的本地副本，或者用来生成基于数据表求和的汇总表。物化视图存储基于远程表的数据，也可以称为快照。</p>
<p>&nbsp;</p>
<p><span style="white-space: pre"></span>物化视图可以用于预先计算并保存表连接或聚集等耗时较多的操作的结果，这样，在执行查询时，就可以避免进行这些耗时的操作，而从快速的得到结果。物化视图有很多方面和索引很相似：使用物化视图的目的是为了提高查询性能；物化视图对应用透明，增加和删除物化视图不会影响应用程序中SQL语句的正确性和有效性；物化视图需要占用存储空间；当基表发生变化时，物化视图也应当刷新。</p>
<p>&nbsp;</p>
<p><span style="white-space: pre"></span>物化视图可以查询表，视图和其它的物化视图。</p>
<p>&nbsp;</p>
<p><span style="white-space: pre"></span>通常情况下，物化视图被称为主表（在复制期间）或明细表（在数据仓库中）。</p>
<p><span style="white-space: pre"></span>对于复制，物化视图允许你在本地维护远程数据的副本,这些副本是只读的。如果你想修改本地副本，必须用高级复制的功能。当你想从一个表或视图中抽取数据时，你可以用从物化视图中抽取。</p>
<p><span style="white-space: pre"></span>对于数据仓库，创建的物化视图通常情况下是聚合视图，单一表聚合视图和连接视图。</p>
<p>在复制环境下，创建的物化视图通常情况下主键，rowid,和子查询视图。</p>
<p>&nbsp;</p>
<p>物化视图由于是物理真实存在的，故可以创建索引。</p>
<p>&nbsp;</p>
<p>&nbsp;</p>
<h3 sizset="76" sizcache="28"><a name="t1"></a><span style="color: red">1.1 </span><span style="color: red">物化视图可以分为以下三种类型</span></h3>
<p>（1）&nbsp;&nbsp;&nbsp; 包含聚集的物化视图；</p>
<p>（2）&nbsp;&nbsp;&nbsp; 只包含连接的物化视图；</p>
<p>（3）&nbsp;&nbsp;&nbsp; 嵌套物化视图。</p>
<p>&nbsp;</p>
<p>三种物化视图的快速刷新的限制条件有很大区别，而对于其他方面则区别不大。创建物化视图时可以指定多种选项，下面对几种主要的选择进行简单说明：</p>
<p>&nbsp;</p>
<p><span style="color: red">（</span><span style="color: red">1</span><span style="color: red">）创建方式（</span><span style="color: red">BuildMethods</span><span style="color: red">）：</span>包括BUILD IMMEDIATE和BUILD DEFERRED两种。</p>
<p>BUILD IMMEDIATE是在创建物化视图的时候就生成数据。</p>
<p>BUILD DEFERRED则在创建时不生成数据，以后根据需要在生成数据。<span style="color: red">默认为</span><span style="color: red">BUILD IMMEDIATE</span><span style="color: red">。</span></p>
<p>&nbsp;</p>
<p><span style="color: red">（</span><span style="color: red">2</span><span style="color: red">）查询重写（</span><span style="color: red">QueryRewrite</span><span style="color: red">）：</span>包括ENABLE QUERY REWRITE和DISABLE QUERY REWRITE两种。</p>
<p>分别指出创建的物化视图是否支持查询重写。查询重写是指当对物化视图的基表进行查询时，Oracle会自动判断能否通过查询物化视图来得到结果，如果可以，则避免了聚集或连接操作，而直接从已经计算好的物化视图中读取数据。<span style="color: red">默认为</span><span style="color: red">DISABLEQUERY REWRITE</span><span style="color: red">。</span></p>
<p>&nbsp;</p>
<p><span style="color: red"><span style="color: red">（</span><span style="color: red">3</span><span style="color: red">）</span>刷新（</span><span style="color: red">Refresh</span><span style="color: red">）：</span>指当基表发生了DML操作后，物化视图何时采用哪种方式和基表进行同步。刷新的模式有两种：ON DEMAND和ON COMMIT。</p>
<p>ON DEMAND和ON COMMIT物化视图的区别在于其刷新方法的不同，ON DEMAND指物化视图在用户需要的时候进行刷新，可以手工通过DBMS_MVIEW.REFRESH等方法来进行刷新，也可以通过JOB定时进行刷新,即更新物化视图，以保证和基表数据的一致性;而ON COMMIT是说，一旦基表有了COMMIT，即事务提交，则立刻刷新，立刻更新物化视图，使得数据和基表一致。</p>
<p>对基表，平常的COMMIT在0.01秒内可以完成，但在有了ON COMMIT视图后，居然要6秒。速度减低了很多倍。ON COMMIT视图对基表的影响可见一斑。 </p>
<p>&nbsp;</p>
<h3 sizset="77" sizcache="28"><a name="t2"></a><span style="color: red">1.2 </span><span style="color: red">物化视图，根据不同的着重点可以有不同的分类</span><span style="color: red">:</span></h3>
<p>1)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;按刷新方式分：FAST/COMPLETE/FORCE</p>
<p>2)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;按刷新时间的不同：ON DEMAND/ON COMMIT</p>
<p>3)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;按是否可更新：UPDATABLE/READ ONLY</p>
<p>4)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;按是否支持查询重写：ENABLE QUERY REWRITE/DISABLEQUERY REWRITE</p>
<p>&nbsp;</p>
<p>默认情况下，如果没指定刷新方法和刷新模式，则Oracle默认为FORCE和DEMAND。</p>
<p>&nbsp;</p>
<p><span style="color: red">注意：设置</span><span style="color: red">REFRESH ON COMMIT</span><span style="color: red">的物化视图不能访问远端对象。</span></p>
<p>&nbsp;</p>
<p>在建立物化视图的时候可以指定ORDER BY语句，使生成的数据按照一定的顺序进行保存。不过这个语句不会写入物化视图的定义中，而且对以后的刷新也无效。</p>
<p>&nbsp;</p>
<h3 sizset="78" sizcache="28"><a name="t3"></a><span style="color: red">1.3 </span><span style="color: red">物化视图有三种刷新方式：</span><span style="color: red">COMPLETE</span><span style="color: red">、</span><span style="color: red">FAST</span><span style="color: red">和&nbsp;</span><span style="color: red">FORCE</span><span style="color: red">。</span></h3>
<p><span style="color: #ff0000">1)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;完全刷新（COMPLETE）</span>会删除表中所有的记录（如果是单表刷新，可能会采用TRUNCATE的方式），然后根据物化视图中查询语句的定义重新生成物化视图。</p>
<p><span style="color: #ff0000">2)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;快速刷新（FAST）</span>采用增量刷新的机制，只将自上次刷新以后对基表进行的所有操作刷新到物化视图中去。FAST必须创建基于主表的视图日志。</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 对于增量刷新选项，如果在子查询中存在分析函数，则物化视图不起作用。</p>
<p><span style="color: #ff0000">3)&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;采用FORCE方式</span>，Oracle会自动判断是否满足快速刷新的条件，如果满足则进行快速刷新，否则进行完全刷新。</p>
<p>&nbsp;</p>
<p><span style="white-space: pre"></span>Oracle物化视图的快速刷新机制是通过物化视图日志完成的。Oracle通过一个物化视图日志还可以支持多个物化视图的快速刷新。</p>
<p><span style="white-space: pre"></span>物化视图日志根据不同物化视图的快速刷新的需要，可以建立为ROWID或PRIMARY KEY类型的。还可以选择是否包括SEQUENCE、INCLUDING NEW VALUES以及指定列的列表。 </p>
<p>&nbsp;</p>
<h3 sizset="79" sizcache="28"><a name="t4"></a><span style="color: red">1.4 </span><span style="color: red">物化视图</span><span style="color: red">Refresh</span><span style="color: red">子句的其他说明与示例</span></h3>
<p>&nbsp;</p>
<p>REFRESH 子句可以包含如下部分：</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;[refresh [fast|complete|force]</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;[on demand | commit]</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;[start with date] [next date]</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;[with {primary key|rowid}]]</p>
<p>&nbsp;</p>
<h3 sizset="80" sizcache="28"><a name="t5"></a><span style="color: red">1.4.1 </span><span style="color: red">主键和</span><span style="color: red">ROWD</span><span style="color: red">子句：</span></h3>
<p><span style="white-space: pre"></span>WITH PRIMARY KEY选项生成主键物化视图,也就是说物化视图是基于主表的主键，而不是ROWID(对应于ROWID子句). PRIMARY KEY是默认选项,为了生成PRIMARY KEY子句，应该在主表上定义主键，否则应该用基于ROWID的物化视图.</p>
<p>&nbsp;</p>
<p><span style="color: #ff0000">基于ROWID物化视图只有一个单一的主表，不能包括下面任何一项:</span></p>
<p>（1）.Distinct 或者聚合函数.</p>
<p>（2）&nbsp;&nbsp;&nbsp; .Group by，子查询，连接和SET操作</p>
<p>&nbsp;</p>
<p><span style="color: red">--</span><span style="color: red">主键（</span><span style="color: red">PrimaryKey</span><span style="color: red">）物化视图示例：</span></p>
<p>在远程数据库表emp上创建主键物化视图：</p>
<p>&nbsp;</p>
<p align="left"><span style="color: #008080"></span></p>
<div class="dp-highlighter bg_sql" sizset="81" sizcache="28">
<div class="bar" sizset="81" sizcache="28">
<div class="tools" sizset="81" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span>CREATEMATERIALIZEDVIEW&nbsp;mv_emp_pk&nbsp;&nbsp;</span></li><li class=""><span>REFRESHFASTSTARTWITHSYSDATE&nbsp;&nbsp;</span></li><li class="alt"><span></span><span class="keyword">NEXT</span><span>&nbsp;&nbsp;SYSDATE&nbsp;+&nbsp;1/48&nbsp;&nbsp;</span></span></li><li class=""><span>WITHPRIMARYKEY&nbsp;&nbsp;</span></li><li class="alt"><span>ASSELECT&nbsp;*&nbsp;</span><span class="keyword">FROM</span><span>&nbsp;emp@remote_db&nbsp;&nbsp;</span></span></li></ol></div><pre class="sql" style="display: none" name="code">CREATEMATERIALIZEDVIEW mv_emp_pk
REFRESHFASTSTARTWITHSYSDATE
NEXT  SYSDATE + 1/48
WITHPRIMARYKEY
ASSELECT * FROM emp@remote_db</pre><br />&nbsp; 
<p>&nbsp;</p>
<p>--当用FAST选项创建物化视图，必须创建基于主表的视图日志,如下:</p>
<p><span style="color: #008080"></span></p>
<div class="dp-highlighter bg_sql" sizset="85" sizcache="28">
<div class="bar" sizset="85" sizcache="28">
<div class="tools" sizset="85" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span>CREATEMATERIALIZEDVIEWLOGON&nbsp;emp;&nbsp;&nbsp;</span></li></ol></div><pre class="sql" style="display: none" name="code">CREATEMATERIALIZEDVIEWLOGON emp;</pre><br /><br />
<p>&nbsp;</p>
<p><span style="color: red">--Rowid</span><span style="color: red">物化视图示例：</span></p>
<p>下面的语法在远程数据库表emp上创建Rowid物化视图</p>
<p align="left"><span style="color: #008080"></span></p>
<div class="dp-highlighter bg_sql" sizset="89" sizcache="28">
<div class="bar" sizset="89" sizcache="28">
<div class="tools" sizset="89" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span>CREATEMATERIALIZEDVIEW&nbsp;mv_emp_rowid&nbsp;&nbsp;</span></li><li class=""><span>REFRESHWITHROWID&nbsp;&nbsp;</span></li><li class="alt"><span>ASSELECT&nbsp;*&nbsp;</span><span class="keyword">FROM</span><span>&nbsp;emp@remote_db;&nbsp;&nbsp;</span></span></li><li class=""><span>Materializedviewlog&nbsp;created.&nbsp;&nbsp;</span></li></ol></div><pre class="sql" style="display: none" name="code">CREATEMATERIALIZEDVIEW mv_emp_rowid
REFRESHWITHROWID
ASSELECT * FROM emp@remote_db;
Materializedviewlog created.</pre>
<p>&nbsp;</p>
<p><span style="color: red">--</span><span style="color: red">子查询物化视图示例：</span></p>
<p>在远程数据库表emp上创建基于emp和dept表的子查询物化视图</p>
<p align="left"><span style="color: #008080"></span></p>
<div class="dp-highlighter bg_sql" sizset="93" sizcache="28">
<div class="bar" sizset="93" sizcache="28">
<div class="tools" sizset="93" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span>CREATEMATERIALIZEDVIEW&nbsp;&nbsp;mv_empdept&nbsp;&nbsp;</span></li><li class=""><span>ASSELECT&nbsp;*&nbsp;</span><span class="keyword">FROM</span><span>&nbsp;emp@remote_db&nbsp;e&nbsp;&nbsp;</span></span></li><li class="alt"><span>WHEREEXISTS&nbsp;&nbsp;</span></li><li class=""><span>(</span><span class="keyword">SELECT</span><span>&nbsp;*&nbsp;</span><span class="keyword">FROM</span><span>&nbsp;dept@remote_db&nbsp;d&nbsp;&nbsp;</span></span></li><li class="alt"><span>WHEREe.dept_no&nbsp;=&nbsp;d.dept_no)&nbsp;&nbsp;</span></li></ol></div><pre class="sql" style="display: none" name="code">CREATEMATERIALIZEDVIEW  mv_empdept
ASSELECT * FROM emp@remote_db e
WHEREEXISTS
(SELECT * FROM dept@remote_db d
WHEREe.dept_no = d.dept_no)</pre>
<p>&nbsp;</p>
<p>&nbsp;</p>
<h3 sizset="97" sizcache="28"><a name="t6"></a><span style="color: red">1.4.2 </span><span style="color: red">刷新时间</span></h3>
<p>START WITH子句通知数据库完成从主表到本地表第一次复制的时间,应该及时估计下一次运行的时间点, NEXT 子句说明了刷新的间隔时间.</p>
<p>&nbsp;</p>
<p align="left"><span style="color: #008080"></span></p>
<div class="dp-highlighter bg_sql" sizset="98" sizcache="28">
<div class="bar" sizset="98" sizcache="28">
<div class="tools" sizset="98" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span>CREATEMATERIALIZEDVIEW&nbsp;mv_emp_pk&nbsp;&nbsp;</span></li><li class=""><span>REFRESHFAST&nbsp;&nbsp;</span></li><li class="alt"><span>STARTWITHSYSDATE&nbsp;&nbsp;</span></li><li class=""><span></span><span class="keyword">NEXT</span><span>&nbsp;&nbsp;SYSDATE&nbsp;+&nbsp;2&nbsp;&nbsp;</span></span></li><li class="alt"><span>WITHPRIMARYKEY&nbsp;&nbsp;</span></li><li class=""><span>ASSELECT&nbsp;*&nbsp;</span><span class="keyword">FROM</span><span>&nbsp;emp@remote_db;&nbsp;&nbsp;</span></span></li></ol></div><pre class="sql" style="display: none" name="code">CREATEMATERIALIZEDVIEW mv_emp_pk
REFRESHFAST
STARTWITHSYSDATE
NEXT  SYSDATE + 2
WITHPRIMARYKEY
ASSELECT * FROM emp@remote_db;</pre><br />&nbsp; 
<p>&nbsp;</p>
<p>在上面的例子中，物化视图数据的第一个副本在创建时生成，以后每两天刷新一次.</p>
<p>&nbsp;</p>
<p align="left"><span style="color: #008080"></span></p>
<div class="dp-highlighter bg_sql" sizset="102" sizcache="28">
<div class="bar" sizset="102" sizcache="28">
<div class="tools" sizset="102" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span>creatematerializedviewMV_LVY_LEVYDETAILDATA&nbsp;&nbsp;</span></li><li class=""><span>TABLESPACE&nbsp;ZGMV_DATA&nbsp;</span><span class="comment">--保存表空间 </span><span>&nbsp;&nbsp;</span></span></li><li class="alt"><span>BUILDDEFERRED</span><span class="comment">--延迟刷新不立即刷新 </span><span>&nbsp;&nbsp;</span></span></li><li class=""><span>refreshforce</span><span class="comment">--如果可以快速刷新则进行快速刷新，否则完全刷新 </span><span>&nbsp;&nbsp;</span></span></li><li class="alt"><span>ondemand</span><span class="comment">--按照指定方式刷新 </span><span>&nbsp;&nbsp;</span></span></li><li class=""><span>startwith&nbsp;to_date(</span><span class="string">'24-11-200518:00:10'</span><span>,&nbsp;</span><span class="string">'dd-mm-yyyyhh24:mi:ss'</span><span>)&nbsp;</span><span class="comment">--第一次刷新时间 </span><span>&nbsp;&nbsp;</span></span></li><li class="alt"><span>nextTRUNC(SYSDATE+1)+18/24</span><span class="comment">--刷新时间间隔 </span><span>&nbsp;&nbsp;</span></span></li><li class=""><span></span><span class="keyword">as</span><span>&nbsp;&nbsp;</span></span></li><li class="alt"><span></span><span class="keyword">SELECT</span><span>&nbsp;*&nbsp;</span><span class="keyword">FROM</span><span>&nbsp;emp@remote_db;&nbsp;&nbsp;</span></span></li></ol></div><pre class="sql" style="display: none" name="code">creatematerializedviewMV_LVY_LEVYDETAILDATA
TABLESPACE ZGMV_DATA --保存表空间
BUILDDEFERRED--延迟刷新不立即刷新
refreshforce--如果可以快速刷新则进行快速刷新，否则完全刷新
ondemand--按照指定方式刷新
startwith to_date('24-11-200518:00:10', 'dd-mm-yyyyhh24:mi:ss') --第一次刷新时间
nextTRUNC(SYSDATE+1)+18/24--刷新时间间隔
as
SELECT * FROM emp@remote_db;</pre><br /><br />
<p>&nbsp;</p>
<h3 sizset="106" sizcache="28"><a name="t7"></a><span style="color: red">1.5 ON PREBUILD TABLE </span><span style="color: red">说明</span></h3>
<p><span style="white-space: pre"></span>在创建物化视图时指明ON PREBUILD TABLE语句，可以将物化视图建立在一个已经存在的表上。这种情况下，物化视图和表必须同名。当删除物化视图时，不会删除同名的表。</p>
<p><span style="color: red">这种物化视图的查询重写要求参数</span><span style="color: red">QUERY_REWRITE_INTEGERITY</span><span style="color: red">必须设置为</span><span style="color: red">trusted</span><span style="color: red">或者</span><span style="color: red">stale_tolerated</span><span style="color: red">。</span></p>
<p>&nbsp;</p>
<h3 sizset="107" sizcache="28"><a name="t8"></a><span style="color: red">1.6 </span><span style="color: red">物化视图分区</span></h3>
<p><span style="white-space: pre"></span>物化视图可以进行分区。而且基于分区的物化视图可以支持分区变化跟踪（PCT）。具有这种特性的物化视图，当基表进行了分区维护操作后，仍然可以进行快速刷新操作。对于聚集物化视图，可以在GROUP BY列表中使用CUBE或ROLLUP，来建立不同等级的聚集物化视图。 </p>
<p>&nbsp;</p>
<p>&nbsp;</p>
<p>相关内容参考：</p>
<p sizset="108" sizcache="28"><a href="http://blog.csdn.net/tianlesoftware/article/details/7720580">Oracle 物化视图日志 与 快速刷新 说明</a></p>
<p sizset="109" sizcache="28"><a href="http://blog.csdn.net/tianlesoftware/article/details/7720580">http://blog.csdn.net/tianlesoftware/article/details/7720580</a></p>
<p>&nbsp;</p>
<p sizset="110" sizcache="28"><a href="http://blog.csdn.net/tianlesoftware/article/details/7719789">Oracle 物化视图 详细错误描述 查看方法</a></p>
<p sizset="111" sizcache="28"><a href="http://blog.csdn.net/tianlesoftware/article/details/7719789">http://blog.csdn.net/tianlesoftware/article/details/7719789</a></p>
<p>&nbsp;</p>
<p sizset="112" sizcache="28"><a href="http://blog.csdn.net/tianlesoftware/article/details/7719679">Oracle 物化视图 快速刷新 限制 说明</a></p>
<p sizset="113" sizcache="28"><a href="http://blog.csdn.net/tianlesoftware/article/details/7719679">http://blog.csdn.net/tianlesoftware/article/details/7719679</a></p>
<p>&nbsp;</p>
<p>&nbsp;</p>
<h2 sizset="114" sizcache="28"><a name="t9"></a><span style="color: red">二．&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: red">物化视图操作示例</span></h2>
<p>&nbsp;</p>
<p><span style="color: red">1.&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: red">创建物化视图需要的权限：</span></p>
<p>&nbsp;</p>
<div class="dp-highlighter bg_sql" sizset="115" sizcache="28">
<div class="bar" sizset="115" sizcache="28">
<div class="tools" sizset="115" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span class="keyword">GRANT</span><span>&nbsp;</span><span class="keyword">CREATE</span><span>&nbsp;MATERIALIZED&nbsp;</span><span class="keyword">VIEW</span><span>&nbsp;</span><span class="keyword">TO</span><span>&nbsp;USER_NAME;&nbsp;&nbsp;</span></li></ol></div><pre class="sql" style="display: none" name="code">GRANT CREATE MATERIALIZED VIEW TO USER_NAME;</pre><br /><br />
<p>&nbsp;</p>
<p><span style="color: red">2.&nbsp;&nbsp;</span><span style="color: red">在源表建立物化视图日志</span><span style="color: red">&nbsp;&nbsp;</span></p>
<p align="left"><span style="color: #0000ff"></span></p>
<div class="dp-highlighter bg_sql" sizset="119" sizcache="28">
<div class="bar" sizset="119" sizcache="28">
<div class="tools" sizset="119" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span class="keyword">CREATE</span><span>&nbsp;MATERIALIZED&nbsp;</span><span class="keyword">VIEW</span><span>&nbsp;LOG&nbsp;</span><span class="keyword">ON</span><span>&nbsp;DAVE&nbsp;&nbsp;</span></li><li class=""><span>TABLESPACE&amp;BISONCU_SPACE&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span class="comment">--&nbsp;日志空间 </span><span>&nbsp;&nbsp;</span></span></li><li class="alt"><span></span><span class="keyword">WITH</span><span>&nbsp;</span><span class="keyword">PRIMARY</span><span>&nbsp;</span><span class="keyword">KEY</span><span>;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span><span class="comment">--&nbsp;指定为主键类型</span><span>&nbsp;&nbsp;</span></span></li></ol></div><pre class="sql" style="display: none" name="code">CREATE MATERIALIZED VIEW LOG ON DAVE
TABLESPACE&amp;BISONCU_SPACE           -- 日志空间
WITH PRIMARY KEY;                   -- 指定为主键类型</pre><br />&nbsp; 
<p>&nbsp;</p>
<p><span style="color: red">3.&nbsp;&nbsp;</span><span style="color: red">授权给中间用户</span><span style="color: red">&nbsp;&nbsp;</span></p>
<p align="left"><span style="color: #0000ff"></span></p>
<div class="dp-highlighter bg_sql" sizset="123" sizcache="28">
<div class="bar" sizset="123" sizcache="28">
<div class="tools" sizset="123" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span class="keyword">GRANT</span><span>&nbsp;</span><span class="keyword">SELECT</span><span>&nbsp;</span><span class="keyword">ON</span><span>&nbsp;DAVE&nbsp;</span><span class="keyword">TO</span><span>&nbsp;ANQING;&nbsp;&nbsp;</span></li><li class=""><span></span><span class="keyword">GRANT</span><span>&nbsp;</span><span class="keyword">SELECT</span><span>&nbsp;</span><span class="keyword">ON</span><span>&nbsp;MLOG$_DAVE&nbsp;</span><span class="keyword">TO</span><span>&nbsp;ANQING;&nbsp;&nbsp;</span></span></li></ol></div><pre class="sql" style="display: none" name="code">GRANT SELECT ON DAVE TO ANQING;
GRANT SELECT ON MLOG$_DAVE TO ANQING;</pre><br /><br />
<p>&nbsp;</p>
<p><span style="color: red">4.&nbsp;&nbsp;</span><span style="color: red">在目标数据库上创建</span><span style="color: red">MATERIALIZED&nbsp;VIEW&nbsp;&nbsp;</span></p>
<p>&nbsp;</p>
<p align="left"><span style="color: #0000ff"></span></p>
<div class="dp-highlighter bg_sql" sizset="127" sizcache="28">
<div class="bar" sizset="127" sizcache="28">
<div class="tools" sizset="127" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span class="keyword">CREATE</span><span>&nbsp;MATERIALIZED&nbsp;</span><span class="keyword">VIEW</span><span>&nbsp;AICS_DAVE&nbsp;&nbsp;</span></li><li class=""><span>TABLESPACE&amp;BISONCS_SPACE&nbsp;&nbsp;</span></li><li class="alt"><span>REFRESH&nbsp;FAST&nbsp;&nbsp;</span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span><span class="keyword">ON</span><span>&nbsp;DEMAND&nbsp;&nbsp;</span></span></li><li class="alt"><span>&nbsp;&nbsp;&nbsp;</span><span class="comment">--第一次刷新时间 </span><span>&nbsp;&nbsp;</span></span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span><span class="comment">--START&nbsp;WITH&nbsp;to_date('2012-01-01&nbsp;20:00:00',&nbsp;'yyyy-mm-dd&nbsp;hh24:mi:ss') </span><span>&nbsp;&nbsp;</span></span></li><li class="alt"><span>&nbsp;&nbsp;&nbsp;START&nbsp;</span><span class="keyword">WITH</span><span>&nbsp;SYSDATE&nbsp;&nbsp;</span></span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span><span class="comment">--刷新时间间隔。每1天刷新一次，时间为凌晨2点 </span><span>&nbsp;&nbsp;</span></span></li><li class="alt"><span>&nbsp;&nbsp;&nbsp;</span><span class="comment">--NEXT&nbsp;TRUNC(SYSDATE,'dd')+1+2/24 </span><span>&nbsp;&nbsp;</span></span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span><span class="keyword">NEXT</span><span>&nbsp;SYSDATE+1/24/20&nbsp;&nbsp;</span></span></li><li class="alt"><span></span><span class="keyword">WITH</span><span>&nbsp;</span><span class="keyword">PRIMARY</span><span>&nbsp;</span><span class="keyword">KEY</span><span>&nbsp;&nbsp;</span></span></li><li class=""><span></span><span class="comment">--USING&nbsp;DEFAULT&nbsp;LOCAL&nbsp;ROLLBACKSEGMENT </span><span>&nbsp;&nbsp;</span></span></li><li class="alt"><span>DISABLE&nbsp;QUERY&nbsp;REWRITE&nbsp;</span><span class="keyword">AS</span><span>&nbsp;&nbsp;</span></span></li><li class=""><span></span><span class="keyword">SELECT</span><span>&nbsp;MODEL_ID,&nbsp;STATUS,MODEL_NAME,&nbsp;MANU_ID,&nbsp;DESCRIPTION,&nbsp;CREATE_TIME,&nbsp;UPDATE_TIME,&nbsp;SW_VERSION&nbsp;&nbsp;</span></span></li><li class="alt"><span></span><span class="keyword">FROM</span><span>&nbsp;AICS_DAVE@LINK_DAVE;&nbsp;&nbsp;</span></span></li></ol></div><pre class="sql" style="display: none" name="code">CREATE MATERIALIZED VIEW AICS_DAVE
TABLESPACE&amp;BISONCS_SPACE
REFRESH FAST
   ON DEMAND
   --第一次刷新时间
   --START WITH to_date('2012-01-01 20:00:00', 'yyyy-mm-dd hh24:mi:ss')
   START WITH SYSDATE
   --刷新时间间隔。每1天刷新一次，时间为凌晨2点
   --NEXT TRUNC(SYSDATE,'dd')+1+2/24
   NEXT SYSDATE+1/24/20
WITH PRIMARY KEY
--USING DEFAULT LOCAL ROLLBACKSEGMENT
DISABLE QUERY REWRITE AS
SELECT MODEL_ID, STATUS,MODEL_NAME, MANU_ID, DESCRIPTION, CREATE_TIME, UPDATE_TIME, SW_VERSION
FROM AICS_DAVE@LINK_DAVE;</pre><br />
<p>&nbsp;</p>
<p><span style="color: red">5.&nbsp;&nbsp;</span><span style="color: red">在目标物化视图上创建索引</span><span style="color: red">&nbsp;</span></p>
<p>&nbsp;</p>
<p align="left"><span style="color: #0000ff"></span></p>
<div class="dp-highlighter bg_sql" sizset="131" sizcache="28">
<div class="bar" sizset="131" sizcache="28">
<div class="tools" sizset="131" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span class="keyword">CREATE</span><span>&nbsp;</span><span class="keyword">INDEX</span><span>&nbsp;IDX_T_DV_CT&nbsp;&nbsp;</span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span><span class="keyword">ON</span><span>&nbsp;AICS_DEV_INFO&nbsp;(CREATE_TIME,&nbsp;UPDATE_TIME)&nbsp;&nbsp;</span></span></li><li class="alt"><span>&nbsp;&nbsp;&nbsp;TABLESPACE&nbsp;&amp;BISON_IDX;&nbsp;&nbsp;</span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span></li><li class="alt"><span></span><span class="keyword">CREATE</span><span>&nbsp;</span><span class="keyword">INDEX</span><span>&nbsp;IDX_T_DV_UT&nbsp;&nbsp;</span></span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span><span class="keyword">ON</span><span>&nbsp;AICS_DEV_INFO&nbsp;(UPDATE_TIME)&nbsp;&nbsp;</span></span></li><li class="alt"><span>&nbsp;&nbsp;&nbsp;TABLESPACE&nbsp;&amp;BISON_IDX;&nbsp;&nbsp;</span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span></li><li class="alt"><span></span><span class="keyword">CREATE</span><span>&nbsp;</span><span class="keyword">INDEX</span><span>&nbsp;I_T_DV_MSISDN&nbsp;&nbsp;</span></span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span><span class="keyword">ON</span><span>&nbsp;AICS_DEV_INFO&nbsp;(MSISDN)&nbsp;&nbsp;</span></span></li><li class="alt"><span>&nbsp;&nbsp;&nbsp;TABLESPACE&nbsp;&amp;BISON_IDX;&nbsp;&nbsp;</span></li></ol></div><pre class="sql" style="display: none" name="code">CREATE INDEX IDX_T_DV_CT
   ON AICS_DEV_INFO (CREATE_TIME, UPDATE_TIME)
   TABLESPACE &amp;BISON_IDX;
 
CREATE INDEX IDX_T_DV_UT
   ON AICS_DEV_INFO (UPDATE_TIME)
   TABLESPACE &amp;BISON_IDX;
 
CREATE INDEX I_T_DV_MSISDN
   ON AICS_DEV_INFO (MSISDN)
   TABLESPACE &amp;BISON_IDX;</pre><br /><br />
<p>&nbsp;</p>
<p>&nbsp;</p>
<p><span style="color: red">6. </span><span style="color: red">物化视图刷新说明</span></p>
<p><span style="color: red">（</span><span style="color: red">1</span><span style="color: red">）使用</span><span style="color: red">dbms_mview.refresh </span><span style="color: red">手工刷新</span></p>
<p>如：</p>
<p align="left"><span style="color: #0000ff"></span></p>
<div class="dp-highlighter bg_sql" sizset="135" sizcache="28">
<div class="bar" sizset="135" sizcache="28">
<div class="tools" sizset="135" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span class="keyword">EXEC</span><span>&nbsp;DBMS_MVIEW.REFRESH(</span><span class="string">'MV_DAVE'</span><span>);&nbsp;&nbsp;</span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span></li><li class="alt"><span></span><span class="comment">--完全刷新 </span><span>&nbsp;&nbsp;</span></span></li><li class=""><span></span><span class="keyword">EXEC</span><span>&nbsp;DBMS_MVIEW.REFRESH(LIST&nbsp;=&gt;&nbsp;</span><span class="string">'MV_DAVE'</span><span>,METHOD&nbsp;=&gt;&nbsp;</span><span class="string">'c'</span><span>);&nbsp;&nbsp;</span></span></li><li class="alt"><span></span><span class="keyword">EXEC</span><span>&nbsp;DBMS_MVIEW.REFRESH(</span><span class="string">'MV_DAVE'</span><span>,</span><span class="string">'C'</span><span>);&nbsp;&nbsp;</span></span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span></li><li class="alt"><span></span><span class="comment">--快速刷新 </span><span>&nbsp;&nbsp;</span></span></li><li class=""><span></span><span class="keyword">EXEC</span><span>&nbsp;DBMS_MVIEW.REFRESH(LIST&nbsp;=&gt;&nbsp;</span><span class="string">'MV_DAVE'</span><span>,METHOD&nbsp;=&gt;&nbsp;</span><span class="string">'f'</span><span>);&nbsp;&nbsp;</span></span></li><li class="alt"><span></span><span class="keyword">EXEC</span><span>&nbsp;DBMS_MVIEW.REFRESH(</span><span class="string">'MV_DAVE'</span><span>,</span><span class="string">'F'</span><span>);&nbsp;&nbsp;</span></span></li></ol></div><pre class="sql" style="display: none" name="code">EXEC DBMS_MVIEW.REFRESH('MV_DAVE');
 
--完全刷新
EXEC DBMS_MVIEW.REFRESH(LIST =&gt; 'MV_DAVE',METHOD =&gt; 'c');
EXEC DBMS_MVIEW.REFRESH('MV_DAVE','C');
 
--快速刷新
EXEC DBMS_MVIEW.REFRESH(LIST =&gt; 'MV_DAVE',METHOD =&gt; 'f');
EXEC DBMS_MVIEW.REFRESH('MV_DAVE','F');</pre><br /><br />
<p>&nbsp;</p>
<p>&nbsp;</p>
<p><span style="color: red">（</span><span style="color: red">2</span><span style="color: red">）使用</span><span style="color: red">dbms_refresh.refresh </span><span style="color: red">过程来批量刷新</span><span style="color: red">MV</span></p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 如果我们在创建物化视图的过程指定start 和next time的刷新时间，那么Oracle 会自动创建刷新的job，并采用dbms_refresh.refresh 的方式。</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 使用这种方式刷新之前需要先make refresh group，然后才可以刷新。</p>
<p>&nbsp;</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Refreshmake 的语法可以参考：</p>
<p sizset="139" sizcache="28"><a href="http://docs.oracle.com/cd/B19306_01/server.102/b14227/rarrefreshpac.htm#i94057">http://docs.oracle.com/cd/B19306_01/server.102/b14227/rarrefreshpac.htm#i94057</a></p>
<p>&nbsp;</p>
<p>示例：</p>
<p sizset="140" sizcache="28">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 假设存在物化视图<a name="OLE_LINK8"></a><a name="OLE_LINK7">MV_T1,</a> MV_T2, MV_T3. 创建refresh group的语法如下：</p>
<p><span style="color: #0000ff"></span></p>
<div class="dp-highlighter bg_sql" sizset="142" sizcache="28">
<div class="bar" sizset="142" sizcache="28">
<div class="tools" sizset="142" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span>SQL&gt;&nbsp;</span><span class="keyword">EXEC</span><span>&nbsp;DBMS_REFRESH.MAKE(</span><span class="string">'REP_TEST'</span><span>,&nbsp;</span><span class="string">'MV_T1,MV_T2,MV_T3'</span><span>,&nbsp;SYSDATE,&nbsp;</span><span class="string">'SYSDATE+&nbsp;1'</span><span>)&nbsp;&nbsp;</span></li><li class=""><span>&nbsp;&nbsp;&nbsp;</span></li><li class="alt"><span></span><span class="comment">--刷新整个refresh&nbsp;group&nbsp;组： </span><span>&nbsp;&nbsp;</span></span></li><li class=""><span>SQL&gt;&nbsp;</span><span class="keyword">EXEC</span><span>&nbsp;DBMS_REFRESH.REFRESH(</span><span class="string">'REP_TEST'</span><span>)&nbsp;&nbsp;</span></span></li></ol></div><pre class="sql" style="display: none" name="code">SQL&gt; EXEC DBMS_REFRESH.MAKE('REP_TEST', 'MV_T1,MV_T2,MV_T3', SYSDATE, 'SYSDATE+ 1')
 
--刷新整个refresh group 组：
SQL&gt; EXEC DBMS_REFRESH.REFRESH('REP_TEST')</pre><br />&nbsp; 
<p>&nbsp;</p>
<p><span style="color: red">7. </span><span style="color: red">删除物化视图及日志</span></p>
<p align="left"><span style="color: #008000"><em></em></span></p>
<div class="dp-highlighter bg_sql" sizset="146" sizcache="28">
<div class="bar" sizset="146" sizcache="28">
<div class="tools" sizset="146" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span class="comment">--删除物化视图日志： </span><span>&nbsp;&nbsp;</span></li><li class=""><span></span><span class="keyword">DROP</span><span>&nbsp;MATERIALIZED&nbsp;</span><span class="keyword">VIEW</span><span>&nbsp;LOG&nbsp;</span><span class="keyword">ON</span><span>&nbsp;DAVE;&nbsp;&nbsp;</span></span></li><li class="alt"><span></span><span class="comment">--删除物化视图 </span><span>&nbsp;&nbsp;</span></span></li><li class=""><span></span><span class="keyword">DROP</span><span>&nbsp;MATERIALIZED&nbsp;</span><span class="keyword">VIEW</span><span>&nbsp;MV_DAVE;&nbsp;&nbsp;</span></span></li></ol></div><pre class="sql" style="display: none" name="code">--删除物化视图日志：
DROP MATERIALIZED VIEW LOG ON DAVE;
--删除物化视图
DROP MATERIALIZED VIEW MV_DAVE;</pre><br />&nbsp; 
<p>&nbsp;</p>
<p><span style="color: red">8. </span><span style="color: red">查看物化视图刷新状态信息</span></p>
<p>&nbsp;</p>
<p align="left"><span style="color: #0000ff"></span></p>
<div class="dp-highlighter bg_sql" sizset="150" sizcache="28">
<div class="bar" sizset="150" sizcache="28">
<div class="tools" sizset="150" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span>SQL&gt;&nbsp;</span><span class="keyword">SELECT</span><span>&nbsp;MVIEW_NAME,&nbsp;LAST_REFRESH_DATE,&nbsp;STALENESS&nbsp;FROMUSER_MVIEWS;&nbsp;&nbsp;</span></li><li class=""><span>SQL&gt;&nbsp;</span><span class="keyword">SELECT</span><span>&nbsp;</span><span class="keyword">NAME</span><span>,&nbsp;LAST_REFRESH&nbsp;</span><span class="keyword">FROM</span><span>&nbsp;USER_MVIEW_REFRESH_TIMES;&nbsp;&nbsp;</span></span></li></ol></div><pre class="sql" style="display: none" name="code">SQL&gt; SELECT MVIEW_NAME, LAST_REFRESH_DATE, STALENESS FROMUSER_MVIEWS;
SQL&gt; SELECT NAME, LAST_REFRESH FROM USER_MVIEW_REFRESH_TIMES;</pre><br />&nbsp; 
<p>&nbsp;</p>
<p><span style="color: red">9. </span><span style="color: red">查询物化视图日志：</span></p>
<p>&nbsp;</p>
<p><span style="color: #0000ff"></span></p>
<div class="dp-highlighter bg_sql" sizset="154" sizcache="28">
<div class="bar" sizset="154" sizcache="28">
<div class="tools" sizset="154" sizcache="28"><strong>[sql]</strong> <a class="ViewSource" title="view plain" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">view plain</font></u></a><a class="CopyToClipboard" title="copy" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">copy</font></u></a><a class="PrintSource" title="print" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">print</font></u></a><a class="About" title="?" href="http://blog.csdn.net/tianlesoftware/article/details/4713553#"><u><font color="#0000ff">?</font></u></a></div></div>
<ol class="dp-sql"><li class="alt"><span class="keyword">SELECT</span><span>&nbsp;*&nbsp;</span><span class="keyword">FROM</span><span>&nbsp;MLOG$_DAVE;&nbsp;&nbsp;</span></li></ol></div><pre class="sql" style="display: none" name="code">SELECT * FROM MLOG$_DAVE;</pre><br /><br />
<p>&nbsp;</p>
<p>&nbsp;</p><img src ="http://www.blogjava.net/tjyhy590/aggbug/413155.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-02 23:02 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/02/413155.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>忘记oracle的sys用户密码怎么修改 </title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413140.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Fri, 02 May 2014 05:16:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413140.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413140.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413140.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413140.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413140.html</trackback:ping><description><![CDATA[<div>一、忘记除SYS、SYSTEM用户之外的用户的登录密码。</div>
<div>&nbsp;用SYS (或SYSTEM)用户登录: CONN SYS/PASS_WORD AS SYSDBA;</div>
<div>&nbsp;使用如下语句修改用户的密码: ALTER USER user_name IDENTIFIED BY "newpass";</div>
<div>&nbsp;注意：密码不能全是数字。并且不能是数字开头。否则会出现：ORA-00988: 口令缺失或无效</div>
<div>二、忘记SYS用户，或者是SYSTEM用户的密码。</div>
<div>&nbsp;如果是忘记SYSTEM用户的密码，可以用SYS用户登录。然后用ALTER USER 命令修改密码：</div>
<div>&nbsp;CONN SYS/PASS_WORD AS SYSDBA;</div>
<div>&nbsp;ALTER USER SYSTEM IDENTIFIED BY "newpass";</div>
<div>&nbsp;如果是忘记SYS用户的密码，可以用SYSTEM用户登录。然后用ALTER USER 命令修改密码。</div>
<div>&nbsp;CONN SYSTEM/PASS_WORD ;</div>
<div>&nbsp;ALTER USER SYSTEM IDENTIFIED BY "newpass";</div>
<div>三、如果SYS,SYSTEM用户的密码都忘记或是丢失。</div>
<div>&nbsp;可以使用ORAPWD.EXE 工具修改密码。</div>
<div>&nbsp;开始菜单-&amp;gt;运行-&amp;gt;输入&#8216;CMD&#8217;,打开命令提示符窗口，输入如下命令：</div>
<div>&nbsp;orapwd file=D:\oracle10g\database\pwdctcsys.ora password=newpass</div>
<div>&nbsp;这个命令重新生成了数据库的密码文件。密码文件的位置在ORACLE_HOME目录下的\database目录下。</div>
<div>&nbsp;这个密码是修改sys用户的密码。除sys其他用户的密码不会改变。</div>
<div>不过Oracle提供了两种验证方式，一种是OS验证，另一种密码文件验证方式，如果是第一种方式用以下方法修改密码：</div>
<div>　　sqlplus /nolog;</div>
<div>　　connect / as sysdba</div>
<div>　　alter user sys identified by ;</div>
<div>　　alter user system identified by ;</div>
<div>　　如果是第二种方法就用上述方式修改，也可以下方法修改密码：</div>
<div>　　orapwd file=pwdxxx.ora password=你设定的新密码 entries=10</div>
<div>　　设定完后，重新启动服务，再次登陆就可以了。</div>
<div>oracle 11g</div>
<div>在本机安装完Oracle以后，不记得sys用户的密码了，采用如下方法可以修改密码：</div>
<div>1.打开cmd，输入sqlplus /nolog，回车；输入&#8220;conn / as sysdba&#8221;;输入&#8220;alter user sys identified by 新密码&#8221;，注意：新密码最好以字母开头，否则可能出现错误Ora-00988。有了这个方法后，只要自己对oracle服务器有管理员权限，不记得密码的时候就可以随意修改密码了。</div>
<div>2.在命令行执行如下命令：sqlplus &#8220;/@服务名 as sysdba&#8221;,然后在sqlplus中alter user sys identified by 新密码;</div>
<div>alter user system identified by 新密码;</div>
<div>3.运行到C盘根目录</div>
<div>1)输入：SET ORACLE_SID = 你的SID名称</div>
<div>2)输入：sqlplus/nolog</div>
<div>3)输入：connect/as sysdba</div>
<div>4)输入：alert user sys identified by sys</div>
<div>5)输入：alert user system identified by system</div>
<div>6)更改完成，密码是Oracle数据库初始密码</div>
<div>4.首先,在CMD下输入SQLPLUS/NOLOG然后再在出来的界面中打入CONN/AS SYSDBA,这样就会以本地系统登录的用户为信任用户进入数据库的操作.解决这个问题的方式有两种,一个是：ALTER USER （USERNAME） IDENTIFIED BY &#8220;密码&#8221;;这个是可以改变USERNAME的密码.当然这个USERNAME必须已经存在的</div>
<div>另一种是：CREATE USER (USERNAME) IDENTIFIED BY &#8220;密码&#8221;;改变用户权限的命令是：GRANT ROLES TO （USERNAME）;以上2种方法都是针对ORACLE 9I的版本 。</div>
<div>5.用orapwd.exe命令，可以修改命令。</div>
<div>orapwd file=&#8217;/oracle/pwdsid.ora&#8217; password=123456这个命令是修改sys用户的密码。你把生成的文件覆盖原来的密码文件。除sys其他用户的密码不会改变。</div>
<div>6.su - oracle</div>
<div>sqlplus /nolog</div>
<div>conn / as sysdba</div>
<div>startup (如果数据库不是处于启动状态则启动)</div>
<div>alter user sys identified by 123456</div>
<div>然后就可以使用sys用户密码登陆了<br /><br />
<div>操作系统认证方式</div>
<div>conn / as sysdba</div>
<div>alter user sys identified by xxx<br /><br /></div></div><img src ="http://www.blogjava.net/tjyhy590/aggbug/413140.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-02 13:16 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/02/413140.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title> oracle修改密码、添加用户及授权 </title><link>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413136.html</link><dc:creator>鸿雁</dc:creator><author>鸿雁</author><pubDate>Fri, 02 May 2014 03:05:00 GMT</pubDate><guid>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413136.html</guid><wfw:comment>http://www.blogjava.net/tjyhy590/comments/413136.html</wfw:comment><comments>http://www.blogjava.net/tjyhy590/archive/2014/05/02/413136.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/tjyhy590/comments/commentRss/413136.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/tjyhy590/services/trackbacks/413136.html</trackback:ping><description><![CDATA[<li style="padding-right: 0px; padding-left: 0px; font-size: 16px; padding-bottom: 0px; margin: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">忘记密码处理 
<blockquote style="padding-right: 3em; padding-left: 3em; font-size: 16px; padding-bottom: 0px; margin: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-style: italic; font-family: Georgia, 'Bitstream Charter', serif">
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">登录：sqlplus/as sysdba;<br />修改：alter user username identified by 密码;</p></blockquote></li><li style="padding-right: 0px; padding-left: 0px; font-size: 16px; padding-bottom: 0px; margin: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">创建新用户 
<blockquote style="padding-right: 3em; padding-left: 3em; font-size: 16px; padding-bottom: 0px; margin: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-style: italic; font-family: Georgia, 'Bitstream Charter', serif">
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">create user 用户名 identified by 密码 default tablespace 表空间名</p></blockquote></li><li style="padding-right: 0px; padding-left: 0px; font-size: 16px; padding-bottom: 0px; margin: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">用户授权 
<blockquote style="padding-right: 3em; padding-left: 3em; font-size: 16px; padding-bottom: 0px; margin: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-style: italic; font-family: Georgia, 'Bitstream Charter', serif">
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">Grant create session to SYSDATA；//授予SYSDATA连接数据的权限<br />系统权限如下：<br />Create session：连接数据库<br />Create sequence：创建序列<br />Create synonym：创建同名对象<br />Create table：创建表<br />Create any table：创建任何模式的表<br />Drop table：删除表<br />Create procedure：创建存储过程<br />Execute any procedure：执行任何模式的存储过程<br />Create user：创建用户<br />Create view：创建视图<br />Drop user：删除用户<br />Drop any table：删除任何模式的表<br />向用户授予系统特权</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">Grant execute any procedure toSYSDATA with admin option<br />此句意思为为sha用户创建系统特权并且可以用SYSDATA为别的用户授予权限</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">连接SYSDATA用户connect SYSDATA/admin</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">可以创建别的用户</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">查看用户权限</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">进入SYSDATA用户connect SYSDATA/admin</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">Select * from user_sys_privs;可以查看到一个列表，<br />列代表用户名权限是否可以给别的用户附加权限（N、Y）</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">行代表权限都有那些</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">撤销用户授予的权限</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">必须连接connect system/admin</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">撤销权限revoke是系统撤销权限的关键词</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">Revoke execute any procedure from SYSDATA；<br />更改用户密码</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">进入SYSDATA用户connect SYSDATA/admin</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">Password输入旧密码输入新密码俩边OK</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">或者用alter user SYSDATA identified by xinmima</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">删除用户</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">Connect system/admin<br />Drop user SYSDATA；<br />为用户授予角色</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">Grant dba to SYSDATA；<br />Grant connect to SYSDATA；<br />Linux下的plsql创建用户</p>
<p style="padding-right: 0px; padding-left: 0px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; padding-top: 0px; background-color: transparent">create user SYSDATA identified by admin<br />Default tablespace user<br />Temporary tablespace temp;<br />Granr unlimited tablespace to SYSDATA；//权限<br />Grant dba to SYSDATA；//角色<br />Grant connect to SYSDATA；</p></blockquote>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">select * from dba_users; //用户表<br />select * from dba_tablespaces; //表空间</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">http://database.51cto.com/art/200911/160296.htm</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">Oracle 权限设置<br />一、权限分类：<br />系统权限：系统规定用户使用数据库的权限。（系统权限是对用户而言)。<br />实体权限：某种权限用户对其它用户的表或视图的存取权限。（是针对表或视图而言的）。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">二、系统权限管理：<br />1、系统权限分类：<br />DBA: 拥有全部特权，是系统最高权限，只有DBA才可以创建数据库结构。<br />RESOURCE:拥有Resource权限的用户只可以创建实体，不可以创建数据库结构。<br />CONNECT:拥有Connect权限的用户只可以登录Oracle，不可以创建实体，不可以创建数据库结构。<br />对于普通用户：授予connect, resource权限。<br />对于DBA管理用户：授予connect，resource, dba权限。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">2、系统权限授权命令：<br />[系统权限只能由DBA用户授出：sys, system(最开始只能是这两个用户)]<br />授权命令：SQL&gt; grant connect, resource, dba to 用户名1 [,用户名2]&#8230;;<br />[普通用户通过授权可以具有与system相同的用户权限，但永远不能达到与sys用户相同的权限，system用户的权限也可以被回收。]<br />例：<br />SQL&gt; connect system/manager<br />SQL&gt; Create user user50 identified by user50;<br />SQL&gt; grant connect, resource to user50;<br />查询用户拥有哪里权限：<br />SQL&gt; select * from dba_role_privs;<br />SQL&gt; select * from dba_sys_privs;<br />SQL&gt; select * from role_sys_privs;<br />删除用户：SQL&gt; drop user 用户名 cascade; //加上cascade则将用户连同其创建的东西全部删除</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">3、系统权限传递：<br />增加WITH ADMIN OPTION选项，则得到的权限可以传递。<br />SQL&gt; grant connect, resorce to user50 with admin option; //可以传递所获权限。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">4、系统权限回收：系统权限只能由DBA用户回收<br />命令：SQL&gt; Revoke connect, resource from user50;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">说明：<br />1）如果使用WITH ADMIN OPTION为某个用户授予系统权限，那么对于被这个用户授予相同权限的所有用户来说，取消该用户的系统权限并不会级联取消这些用户的相同权限。<br />2）系统权限无级联，即A授予B权限，B授予C权限，如果A收回B的权限，C的权限不受影响；系统权限可以跨用户回收，即A可以直接收回C用户的权限。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">三、实体权限管理<br />1、实体权限分类：select, update, insert, alter, index, delete, all //all包括所有权限<br />execute //执行存储过程权限<br />user01:<br />SQL&gt; grant select, update, insert on product to user02;<br />SQL&gt; grant all on product to user02;<br />user02:<br />SQL&gt; select * from user01.product;<br />// 此时user02查user_tables，不包括user01.product这个表，但如果查all_tables则可以查到，因为他可以访问。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">2. 将表的操作权限授予全体用户：<br />SQL&gt; grant all on product to public; // public表示是所有的用户，这里的all权限不包括drop。<br />[实体权限数据字典]:<br />SQL&gt; select owner, table_name from all_tables; // 用户可以查询的表<br />SQL&gt; select table_name from user_tables; // 用户创建的表<br />SQL&gt; select grantor, table_schema, table_name, privilege from all_tab_privs; // 获权可以存取的表（被授权的）<br />SQL&gt; select grantee, owner, table_name, privilege from user_tab_privs; // 授出权限的表(授出的权限)</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">3. DBA用户可以操作全体用户的任意基表(无需授权，包括删除)：<br />DBA用户：<br />SQL&gt; Create table stud02.product(<br />id number(10),<br />name varchar2(20));<br />SQL&gt; drop table stud02.emp;<br />SQL&gt; create table stud02.employee<br />as<br />select * from scott.emp;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">4. 实体权限传递(with grant option)：<br />user01:<br />SQL&gt; grant select, update on product to user02 with grant option; // user02得到权限，并可以传递。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">5. 实体权限回收：<br />user01:<br />SQL&gt;Revoke select, update on product from user02; //传递的权限将全部丢失。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">说明<br />1）如果取消某个用户的对象权限，那么对于这个用户使用WITH GRANT OPTION授予权限的用户来说，同样还会取消这些用户的相同权限，也就是说取消授权时级联的。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">Oracle 用户管理<br />一、创建用户的Profile文件<br />SQL&gt; create profile student limit // student为资源文件名<br />FAILED_LOGIN_ATTEMPTS 3 //指定锁定用户的登录失败次数<br />PASSWORD_LOCK_TIME 5 //指定用户被锁定天数<br />PASSWORD_LIFE_TIME 30 //指定口令可用天数</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">二、创建用户<br />SQL&gt; Create User username<br />Identified by password<br />Default Tablespace tablespace<br />Temporary Tablespace tablespace<br />Profile profile<br />Quota integer/unlimited on tablespace;<br />例:<br />SQL&gt; Create user acc01<br />identified by acc01 // 如果密码是数字，请用双引号括起来<br />default tablespace account<br />temporary tablespace temp<br />profile default<br />quota 50m on account;<br />SQL&gt; grant connect, resource to acc01;<br />[*] 查询用户缺省表空间、临时表空间<br />SQL&gt; select username, default_tablespace, temporary_tablespace from dba_users;<br />[*] 查询系统资源文件名：<br />SQL&gt; select * from dba_profiles;<br />资源文件类似表，一旦创建就会保存在数据库中。<br />SQL&gt; select username, profile, default_tablespace, temporary_tablespace from dba_users;<br />SQL&gt; create profile common limit<br />failed_login_attempts 5<br />idle_time 5;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">SQL&gt; Alter user acc01 profile common;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">三、修改用户：<br />SQL&gt; Alter User 用户名<br />Identified 口令<br />Default Tablespace tablespace<br />Temporary Tablespace tablespace<br />Profile profile<br />Quota integer/unlimited on tablespace;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">1、修改口令字：<br />SQL&gt;Alter user acc01 identified by &#8220;12345&#8243;;<br />2、修改用户缺省表空间：<br />SQL&gt; Alter user acc01 default tablespace users;<br />3、修改用户临时表空间<br />SQL&gt; Alter user acc01 temporary tablespace temp_data;<br />4、强制用户修改口令字：<br />SQL&gt; Alter user acc01 password expire;<br />5、将用户加锁<br />SQL&gt; Alter user acc01 account lock; // 加锁<br />SQL&gt; Alter user acc01 account unlock; // 解锁</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">四、删除用户<br />SQL&gt;drop user 用户名; //用户没有建任何实体<br />SQL&gt; drop user 用户名 CASCADE; // 将用户及其所建实体全部删除<br />*1. 当前正连接的用户不得删除。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">五、监视用户：<br />1、查询用户会话信息：<br />SQL&gt; select username, sid, serial#, machine from v$session;<br />2、删除用户会话信息：<br />SQL&gt; Alter system kill session &#8216;sid, serial#&#8217;;<br />3、查询用户SQL语句：<br />SQL&gt; select user_name, sql_text from v$open_cursor;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">Oracle 角色管理<br />一、何为角色<br />　　角色。角色是一组权限的集合，将角色赋给一个用户，这个用户就拥有了这个角色中的所有权限。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">二、系统预定义角色<br />　　预定义角色是在数据库安装后，系统自动创建的一些常用的角色。下介简单的介绍一下这些预定角色。角色所包含的权限可以用以下语句查询：<br />sql&gt;select * from role_sys_privs where role=&#8217;角色名&#8217;;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">1．CONNECT, RESOURCE, DBA<br />这些预定义角色主要是为了向后兼容。其主要是用于数据库管理。oracle建议用户自己设计数据库管理和安全的权限规划，而不要简单的使用这些预定角色。将来的版本中这些角色可能不会作为预定义角色。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">2．DELETE_CATALOG_ROLE， EXECUTE_CATALOG_ROLE， SELECT_CATALOG_ROLE<br />这些角色主要用于访问数据字典视图和包。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">3．EXP_FULL_DATABASE， IMP_FULL_DATABASE<br />这两个角色用于数据导入导出工具的使用。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">4．AQ_USER_ROLE， AQ_ADMINISTRATOR_ROLE<br />AQ:Advanced Query。这两个角色用于oracle高级查询功能。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">5． SNMPAGENT<br />用于oracle enterprise manager和Intelligent Agent</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">6．RECOVERY_CATALOG_OWNER<br />用于创建拥有恢复库的用户。关于恢复库的信息，参考oracle文档《Oracle9i User-Managed Backup and Recovery Guide》</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">7．HS_ADMIN_ROLE<br />A DBA using Oracle&#8217;s heterogeneous services feature needs this role to access appropriate tables in the data dictionary.</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">三、管理角色<br />1.建一个角色<br />sql&gt;create role role1;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">2.授权给角色<br />sql&gt;grant create any table,create procedure to role1;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">3.授予角色给用户<br />sql&gt;grant role1 to user1;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">4.查看角色所包含的权限<br />sql&gt;select * from role_sys_privs;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">5.创建带有口令以角色(在生效带有口令的角色时必须提供口令)<br />sql&gt;create role role1 identified by password1;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">6.修改角色：是否需要口令<br />sql&gt;alter role role1 not identified;<br />sql&gt;alter role role1 identified by password1;</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">7.设置当前用户要生效的角色<br />(注：角色的生效是一个什么概念呢？假设用户a有b1,b2,b3三个角色，那么如果b1未生效，则b1所包含的权限对于a来讲是不拥有的，只有角色生效了，角色内的权限才作用于用户，最大可生效角色数由参数MAX_ENABLED_ROLES设定；在用户登录后，oracle将所有直接赋给用户的权限和用户默认角色中的权限赋给用户。）<br />sql&gt;set role role1;//使role1生效<br />sql&gt;set role role,role2;//使role1,role2生效<br />sql&gt;set role role1 identified by password1;//使用带有口令的role1生效<br />sql&gt;set role all;//使用该用户的所有角色生效<br />sql&gt;set role none;//设置所有角色失效<br />sql&gt;set role all except role1;//除role1外的该用户的所有其它角色生效。<br />sql&gt;select * from SESSION_ROLES;//查看当前用户的生效的角色。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">8.修改指定用户，设置其默认角色<br />sql&gt;alter user user1 default role role1;<br />sql&gt;alter user user1 default role all except role1;<br />详见oracle参考文档</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">9.删除角色<br />sql&gt;drop role role1;<br />角色删除后，原来拥用该角色的用户就不再拥有该角色了，相应的权限也就没有了。</p>
<p style="padding-right: 0px; padding-left: 0px; font-size: 16px; margin-bottom: 24px; padding-bottom: 0px; vertical-align: baseline; color: #333333; line-height: 24px; padding-top: 0px; font-family: Georgia, 'Bitstream Charter', serif">说明:<br />1)无法使用WITH GRANT OPTION为角色授予对象权限<br />2)可以使用WITH ADMIN OPTION 为角色授予系统权限,取消时不是级联</p></li> <img src ="http://www.blogjava.net/tjyhy590/aggbug/413136.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/tjyhy590/" target="_blank">鸿雁</a> 2014-05-02 11:05 <a href="http://www.blogjava.net/tjyhy590/archive/2014/05/02/413136.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>