﻿<?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>C++博客-时间的痕迹-文章分类-ORACLE</title><link>http://www.cppblog.com/ivenher/category/2686.html</link><description /><language>zh-cn</language><lastBuildDate>Mon, 19 May 2008 21:51:54 GMT</lastBuildDate><pubDate>Mon, 19 May 2008 21:51:54 GMT</pubDate><ttl>60</ttl><item><title>OTL性能</title><link>http://www.cppblog.com/ivenher/articles/39973.html</link><dc:creator>爱饭盒</dc:creator><author>爱饭盒</author><pubDate>Sat, 29 Dec 2007 16:18:00 GMT</pubDate><guid>http://www.cppblog.com/ivenher/articles/39973.html</guid><wfw:comment>http://www.cppblog.com/ivenher/comments/39973.html</wfw:comment><comments>http://www.cppblog.com/ivenher/articles/39973.html#Feedback</comments><slash:comments>1</slash:comments><wfw:commentRss>http://www.cppblog.com/ivenher/comments/commentRss/39973.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/ivenher/services/trackbacks/39973.html</trackback:ping><description><![CDATA[<p>今天在做一个程序性能提升时发现otl_stream.第一个参数buffer size 对性能影响很大,以下是几个测试数据.<br>参考: <a href="http://otl.sourceforge.net/otl3_stream_class.htm">http://otl.sourceforge.net/otl3_stream_class.htm</a><br>50&nbsp;&nbsp; 2.06<br>&lt;1:536704&gt; 18:31:58.068 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:536704&gt; 18:34:04.713 [00001] There are 3612066 records is loaded!</p>
<p>100 1.38<br>&lt;1:2085112&gt; 18:36:23.727 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:2085112&gt; 18:38:01.923 [00001] There are 3612066 records is loaded!<br>1.23<br>&lt;1:2085112&gt; 18:38:06.941 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:2085112&gt; 18:39:29.849 [00001] There are 3612066 records is loaded!</p>
<p>200&nbsp; 1.02<br>&lt;1:1499250&gt; 18:41:47.711 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:1499250&gt; 18:42:49.300 [00001] There are 3612066 records is loaded!<br>&lt;1:1499250&gt; 18:42:54.312 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:1499250&gt; 18:43:53.717 [00001] There are 3612066 records is loaded!<br>500&nbsp; 0.43<br>&lt;1:1978536&gt; 18:45:57.790 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:1978536&gt; 18:46:40.685 [00001] There are 3612066 records is loaded!<br>&lt;1:1978536&gt; 18:45:09.982 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:1978536&gt; 18:45:52.787 [00001] There are 3612066 records is loaded!<br>1000&nbsp; 0.35<br>&lt;1:1597632&gt; 18:47:42.973 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:1597632&gt; 18:48:17.715 [00001] There are 3612066 records is loaded!<br>&lt;1:1597632&gt; 18:48:22.718 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:1597632&gt; 18:49:01.119 [00001] There are 3612066 records is loaded!<br>&lt;1:1597632&gt; 18:51:17.837 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:1597632&gt; 18:51:24.416 [10001] Signal 31 recieved.<br>&lt;1:1597632&gt; 18:49:49.976 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:1597632&gt; 18:50:28.192 [00001] There are 3612066 records is loaded!</p>
<p>2000&nbsp; 0.34<br>&lt;1:2883830&gt; 18:51:47.365 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:2883830&gt; 18:52:21.163 [00001] There are 3612066 records is loaded!<br>&lt;1:2883830&gt; 18:52:26.166 [00001] The load SQL is [select USER_NUMBER from dr_gsm_931_20050831 where 1=1 ]<br>&lt;1:2883830&gt; 18:53:01.576 [00001] There are 3612066 records is loaded!</p>
另外,编译时定义<a href="http://otl.sourceforge.net/otl3_compile.htm#OTL_STREAM_POOLING_ON"><u><font color=#0000ff>OTL_STREAM_POOLING_ON</font></u></a>&nbsp;也会对性能有所提升.<br>参考: <a href="http://otl.sourceforge.net/otl3_ex113.htm">http://otl.sourceforge.net/otl3_ex113.htm</a><br>
<img src ="http://www.cppblog.com/ivenher/aggbug/39973.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/ivenher/" target="_blank">爱饭盒</a> 2007-12-30 00:18 <a href="http://www.cppblog.com/ivenher/articles/39973.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>oracle-plsql 异常处理（ 4 ） </title><link>http://www.cppblog.com/ivenher/articles/14133.html</link><dc:creator>爱饭盒</dc:creator><author>爱饭盒</author><pubDate>Wed, 25 Oct 2006 08:26:00 GMT</pubDate><guid>http://www.cppblog.com/ivenher/articles/14133.html</guid><wfw:comment>http://www.cppblog.com/ivenher/comments/14133.html</wfw:comment><comments>http://www.cppblog.com/ivenher/articles/14133.html#Feedback</comments><slash:comments>1</slash:comments><wfw:commentRss>http://www.cppblog.com/ivenher/comments/commentRss/14133.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/ivenher/services/trackbacks/14133.html</trackback:ping><description><![CDATA[
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: center" align="center">
				<b>
						<span style="FONT-FAMILY: 宋体" twffan="done">异常处理</span>
						<span lang="EN-US" twffan="done">
								<?xml:namespace prefix = o /?>
								<o:p>
								</o:p>
						</span>
				</b>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">当异常生成之后，程序被中止，控制权交给异常处理模块，异常处理模块捕获当前异常句柄，并交由相应的程序处理；如果，异常促里模块没有捕捉到异常句柄，那么它将被传输到当前程序的外围。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">除非由一些特殊的要求，一般情况下异常将再当前程序的异常处理模块中被处理。异常处理模块以</span>
				<span lang="EN-US" twffan="done">EXCEPTION</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">开始</span>
				<span lang="EN-US" twffan="done">END;</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">结尾。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>Declare</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>
						<span twffan="done">       </span>/*…………*/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>
						<span twffan="done">       </span>/*…………*/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>when /*</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">异常名称</span>
				<span lang="EN-US" twffan="done">*/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>then /*</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">异常处理</span>
				<span lang="EN-US" twffan="done">*/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>when other</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>then /*</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">异常处理</span>
				<span lang="EN-US" twffan="done">*/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>end;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">异常处理模块的语法基本上以</span>
				<span lang="EN-US" twffan="done">CASE</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">一致，凡是在</span>
				<span lang="EN-US" twffan="done">when</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">中有定义的异常都将被处理，而没有的则被传输。一个特殊的异常处理语句是</span>
				<span lang="EN-US" twffan="done">WHEN OTHERS</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">。就想在（</span>
				<span lang="EN-US" twffan="done">3</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">）中所说的，它会处理所有为被处理的异常，因此必须小心使用它，最好是在最外层的程序中。当然如果喜欢偷懒的，大可以在异常处理模块中只放一个</span>
				<span lang="EN-US" twffan="done">OTHERS</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">。注意，无论哪种情况，</span>
				<span lang="EN-US" twffan="done">OTHERS</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">只能这只在异常处理的最后一位。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">有趣的是，可以在一个</span>
				<span lang="EN-US" twffan="done">when</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">中处理多个异常句柄。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>Exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>When no_data_found or invalid_employee_id or dbms_ldap.invalid session</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>Then /*………..*/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>End;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">在这个例子里，有标准包的异常、自定义异常和非标准包中的异常。这些异常只能用</span>
				<span lang="EN-US" twffan="done">or</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">连接，不可以用</span>
				<span lang="EN-US" twffan="done">and</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">，因为只有一个异常能够生成。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">非</span>
				<span lang="EN-US" twffan="done">raise_application_error</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">生成的异常，如果没有被处理而一直传递到系统环境中，那么环境将视情况作出相应的反映。在</span>
				<span lang="EN-US" twffan="done">sqlplus</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">中，</span>
				<span lang="EN-US" twffan="done">oracle</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">将回滚所有</span>
				<span lang="EN-US" twffan="done">DML</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">对数据所做的修改。在</span>
				<span lang="EN-US" twffan="done">sqlplus</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">环境中，因为有自动回滚的存在，我们可以保留出现未被处理的异常的可能性；而在另外的一些环境中，则需要仔细设计最外层程序。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">ü<span style="FONT: 7pt 'Times New Roman'; font-size-adjust: none; font-stretch: normal" twffan="done">         </span></span>
				<span style="FONT-FAMILY: 宋体" twffan="done">捕捉任何有可能传出的异常。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">ü<span style="FONT: 7pt 'Times New Roman'; font-size-adjust: none; font-stretch: normal" twffan="done">         </span></span>
				<span style="FONT-FAMILY: 宋体" twffan="done">记录错误以便于分析。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">ü<span style="FONT: 7pt 'Times New Roman'; font-size-adjust: none; font-stretch: normal" twffan="done">         </span></span>
				<span style="FONT-FAMILY: 宋体" twffan="done">给外部环境一个信息，以便于其作出相应的处理。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">对于自定义异常，因为</span>
				<span lang="EN-US" twffan="done">sqlcode</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">值永远是</span>
				<span lang="EN-US" twffan="done">1</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">，所以当它被传出时，如果外围程序中没有定义相同名称的异常，我们将不知道是什么异常产生了。因此，不要将自定义异常传递出去。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">在程序中处理几个互相独立的操作时，为了避免出现因为一个操作产生异常而使整个程序被中断的情况，有必要将这些独立的操作放在各自的虚拟块中。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>Procedure change_data is</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>Begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>Begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>
						<span twffan="done">       </span>Delete from employee where …..</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>
						<span twffan="done">       </span>Exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>
						<span twffan="done">       </span>When others then null;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>End;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>Begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>
						<span twffan="done">       </span>Update company set …….</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>
						<span twffan="done">       </span>Exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: 21pt">
				<span lang="EN-US" twffan="done">When others then null;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>End;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>Begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>
						<span twffan="done">       </span>Insert into company_history select * from company where ….</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>
						<span twffan="done">       </span>Exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>
						<span twffan="done">       </span>When others then null;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>End;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>End;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<b>
						<span lang="EN-US" twffan="done">Pl/sql</span>
				</b>
				<b>
						<span style="FONT-FAMILY: 宋体" twffan="done">提供了一些内建的函数来帮助我们确定、分析异常。</span>
						<span lang="EN-US" twffan="done">
								<o:p>
								</o:p>
						</span>
				</b>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">SQLCODE</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">这个函数在前面有提到过，它是一个用于返回当前模块中最近一次异常值的函数，或者说是非入栈程序的异常值。打个比方：如果在当前程序的异常模块中调用了另一个程序，</span>
				<span lang="EN-US" twffan="done">oracle</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">将当前程序及相应的环境变量（包括异常值）压入系统栈；在被调用程序中生成了一个值为</span>
				<span lang="EN-US" twffan="done">1</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">的异常，那么</span>
				<span lang="EN-US" twffan="done">sqlcode</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">将返回</span>
				<span lang="EN-US" twffan="done">1</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">；之后刚才的程序出栈，</span>
				<span lang="EN-US" twffan="done">sqlcode</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">返回当前异常值。需要注意的是，不要在异常模块之外使用它，这样不会有任何意义。当没有异常或在异常模块之外使用时，</span>
				<span lang="EN-US" twffan="done">SQLCODE</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">返回</span>
				<span lang="EN-US" twffan="done">0</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">；返回值</span>
				<span lang="EN-US" twffan="done">1</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">是指自定义异常。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">SQLERRM</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">接收异常值，返回相应的长度不超过</span>
				<span lang="EN-US" twffan="done">512</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">字节的描述语。如果没有传入异常值，则返回当前异常描述。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>Begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>
						<span twffan="done">       </span>Dbms_output.put_line( sqlerrm(-1403);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>End;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">Sql&gt;/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">Ora-1403: no data found</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">在需要体构长度超过</span>
				<span lang="EN-US" twffan="done">512 </span>
				<span style="FONT-FAMILY: 宋体" twffan="done">字节的描述时，</span>
				<span lang="EN-US" twffan="done">oracle</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">建议使用</span>
				<span lang="EN-US" twffan="done">dbms_utility.format_error_stack</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">。显然，用这个函数来判断一个异常是否为系统异常是很有用的，如果不是的话，将返回以下两种情况的一种。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">如果是一个负数：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>ora-nnnnn: message not found,; product=rdbms; facility=ora</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">如果是一个正数：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>-nnnnn: non-oracle exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">DBMS_UTILITY.FORMAT_ERROR_STACK</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">返回当前异常相应的描述，没有字符长度限制。与</span>
				<span lang="EN-US" twffan="done">SQLCODE</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">相同的是，必须在异常处理模块中使用。虽然名称中有一个</span>
				<span lang="EN-US" twffan="done">stack</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">在，但通过它并不能知道异常的最初生成处，需要的话就必须使用</span>
				<span lang="EN-US" twffan="done">DBMS_UTILITY.FORMAT_ERROR_BACKTRACE</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">DBMS_UTILITY.FORMAT_ERROR_BACKTRACE</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">系统为最近一次生成的异常设置了一个栈，并跟踪它的传递过程，而这个函数使用这个栈，然后返回该异常的整个传递过程。这个函数对错误的定位和实施下一步处理起着至关重要的作用。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>Create or replace procedure procl is</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>Begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>
						<span twffan="done">       </span>Dbms_output.put_line(‘running proc1’);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>Raise no_data_found;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>End;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>create or replace procedure proc2 is</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>
						<span twffan="done">       </span>dbms_output.put_line(‘calling proc1’);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>proc1;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>end;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>create or replace procedure proc3 is</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>
						<span twffan="done">       </span>dbms_output.put_line(‘calling proc2’);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>proc2;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>when no_data_found</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>then</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>
						<span twffan="done">       </span>dbms_output.put_line(‘error stack at top level’);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">              </span>
						<span twffan="done">       </span>dbms_output.put_line(dbms_utility.format_error_backtrace);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>end;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">       </span>/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">现在可以运行</span>
				<span lang="EN-US" twffan="done">proc3</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">来看看结果。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">Sql&gt;set serveroutput on;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">Sql&gt;begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 42pt; TEXT-INDENT: -42pt">
				<span lang="EN-US" twffan="done">2<span style="FONT: 7pt 'Times New Roman'; font-size-adjust: none; font-stretch: normal" twffan="done">                         </span></span>
				<span lang="EN-US" twffan="done">dbms_output.put_line(‘proc3-&gt;proc2-&gt;proc1 backtrace’);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 42pt; TEXT-INDENT: -42pt">
				<span lang="EN-US" twffan="done">3<span style="FONT: 7pt 'Times New Roman'; font-size-adjust: none; font-stretch: normal" twffan="done">                         </span></span>
				<span lang="EN-US" twffan="done">proc3;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">4<span twffan="done">     </span>end;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">5<span twffan="done">     </span>/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">    </span>Proc3 -&gt; Proc2 -&gt; Proc1 backtrace</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">    </span>calling proc2</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">    </span>calling proc1</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">    </span>running proc1</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">    </span>Error stack at top level:</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">    </span>ORA-06512: at "SCOTT.PROC1", line 4</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span twffan="done">    </span>ORA-06512: at "SCOTT.PROC2", line 5</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21.75pt">
				<span lang="EN-US" twffan="done">ORA-06512: at "SCOTT.PROC3", line 4</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">事实上，每次异常的产生都将重置这个异常栈，只是最后一次从系统栈出栈的是最外层的程序块，所以可以清楚地看到异常生成的整个过程。上面这个程序的执行过程是这样的：首先用</span>
				<span lang="EN-US" twffan="done">put_line</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">打印</span>
				<span lang="EN-US" twffan="done">Proc3 -&gt; Proc2 -&gt; Proc1 backtrace</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">，</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">调用</span>
				<span lang="EN-US" twffan="done">proc3</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">，当前程序入栈</span>
				<span lang="EN-US" twffan="done">=&gt; </span>
				<span style="FONT-FAMILY: 宋体" twffan="done">打印</span>
				<span lang="EN-US" twffan="done">calling proc2</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">，调用</span>
				<span lang="EN-US" twffan="done">proc2</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">，</span>
				<span lang="EN-US" twffan="done">proc3</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">入栈</span>
				<span lang="EN-US" twffan="done">=&gt;</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">打印</span>
				<span lang="EN-US" twffan="done">calling proc1</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">，调用</span>
				<span lang="EN-US" twffan="done">proc1</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">，</span>
				<span lang="EN-US" twffan="done">proc2</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">入栈</span>
				<span lang="EN-US" twffan="done">=&gt; </span>
				<span style="FONT-FAMILY: 宋体" twffan="done">打印</span>
				<span lang="EN-US" twffan="done">running proc1</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">，生成</span>
				<span lang="EN-US" twffan="done">no_data_found</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">异常，该异常被压入异常栈中</span>
				<span lang="EN-US" twffan="done">=&gt;<span twffan="done">  </span>proc2</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">出栈，并检测到来自第</span>
				<span lang="EN-US" twffan="done">5</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">行调用传递过来的异常，将它在此压入异常栈</span>
				<span lang="EN-US" twffan="done">=&gt; proc3</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">出栈，并检测到来自第</span>
				<span lang="EN-US" twffan="done">4</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">行调用传递过来的异常，将它在此压入异常栈，</span>
				<span lang="EN-US" twffan="done">dbms_utility.format_error_backtrace</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">将异常栈中信息反相打印出来</span>
				<span lang="EN-US" twffan="done">=&gt;<span twffan="done">  </span></span>
				<span style="FONT-FAMILY: 宋体" twffan="done">最外层程序出栈，</span>
				<span lang="EN-US" twffan="done">end</span>
				<span style="FONT-FAMILY: 宋体" twffan="done">。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">以下是正确使用这个函数的一些注意事项：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">ü<span style="FONT: 7pt 'Times New Roman'; font-size-adjust: none; font-stretch: normal" twffan="done">         </span></span>
				<span style="FONT-FAMILY: 宋体" twffan="done">在当前程序的异常处理模块中调用这个函数。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">ü<span style="FONT: 7pt 'Times New Roman'; font-size-adjust: none; font-stretch: normal" twffan="done">         </span></span>
				<span style="FONT-FAMILY: 宋体" twffan="done">避免在中间程序中使用异常处理模块。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体" twffan="done">这样异常就能被正确地传输到最外层程序中，并打印出这个过程了。</span>
		</p>
<img src ="http://www.cppblog.com/ivenher/aggbug/14133.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/ivenher/" target="_blank">爱饭盒</a> 2006-10-25 16:26 <a href="http://www.cppblog.com/ivenher/articles/14133.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle:pl/sql 异常处理 （3）</title><link>http://www.cppblog.com/ivenher/articles/14132.html</link><dc:creator>爱饭盒</dc:creator><author>爱饭盒</author><pubDate>Wed, 25 Oct 2006 08:24:00 GMT</pubDate><guid>http://www.cppblog.com/ivenher/articles/14132.html</guid><wfw:comment>http://www.cppblog.com/ivenher/comments/14132.html</wfw:comment><comments>http://www.cppblog.com/ivenher/articles/14132.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/ivenher/comments/commentRss/14132.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/ivenher/services/trackbacks/14132.html</trackback:ping><description><![CDATA[
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">处理</span>
				<span lang="EN-US" twffan="done">oracle</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">系统自动生成系统异常外，可以使用</span>
				<span lang="EN-US" twffan="done">raise</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">来手动生成错误。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt; mso-list: l0 level1 lfo1; tab-stops: list 21.0pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">l<span style="FONT: 7pt 'Times New Roman'" twffan="done">         </span></span>
				<span lang="EN-US" twffan="done">Raise exception;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt; mso-list: l0 level1 lfo1; tab-stops: list 21.0pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">l<span style="FONT: 7pt 'Times New Roman'" twffan="done">         </span></span>
				<span lang="EN-US" twffan="done">Raise package.exception;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt; mso-list: l0 level1 lfo1; tab-stops: list 21.0pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">l<span style="FONT: 7pt 'Times New Roman'" twffan="done">         </span></span>
				<span lang="EN-US" twffan="done">Raise;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">以上是</span>
				<span lang="EN-US" twffan="done">raise</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">的三种使用方法。第一种用于生成当前程序中定义的异常或在</span>
				<span lang="EN-US" twffan="done">standard</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">中的系统异常。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Declare</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Invalid_id exception;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Id_values varchar(2);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Id_value:=id_for(‘smith’);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>If substr(id_value,1,1)!=’x’</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>Then</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Raise invalid_id;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>End if;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>When invalid_id</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>Then</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Dbms_output.put_line(‘this is an invalid id!’);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>End;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">这是一个生成自定义异常的例子，当然也可以生成系统异常：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>declare </span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>employee_id_in number;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 42pt">
				<span lang="EN-US" twffan="done">Select employee_id into employee_id_in from employ_list where employee_name=&amp;n;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 42pt">
				<span lang="EN-US" twffan="done">If employee_id_in=0</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 42pt">
				<span lang="EN-US" twffan="done">Then</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 42pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Raise zero_devided;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 42pt">
				<span lang="EN-US" twffan="done">End if;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>When zero_devided</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>Then</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Dbms_output.put_line(‘wrong!’);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>End;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">有一些异常是定义在非标准包中的，如</span>
				<span lang="EN-US" twffan="done">UTL_FILE</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">，</span>
				<span lang="EN-US" twffan="done">DBMS_SQL</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">以及程序员创建的包中异常。可以使用</span>
				<span lang="EN-US" twffan="done">raise</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">的第二种用法来生成异常。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>If day_overdue(isbn_in, browser_in) &gt; 365</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Then</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>Raise overdue_pkg.book_is_lost</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>End if;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">在最后一种</span>
				<span lang="EN-US" twffan="done">raise</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">的形式中，不带任何参数。这种情况只出现在希望将当前的异常传到外部程序时。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>When no_data_found</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>Then</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Raise;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>End;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /?><o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">Pl.sql</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">使用</span>
				<span lang="EN-US" twffan="done">raise_application_error</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">过程来生成一个有具体描述的异常。当使用这个过程时，当前程序被中止，输入输出参数被置为原先的值，但任何</span>
				<span lang="EN-US" twffan="done">DML</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">对数据库所做的改动将被保留，可以在之后用</span>
				<span lang="EN-US" twffan="done">rollback</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">命令回滚。下面是该过程的原型：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Procedure raise_application_error(</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Num binary_integer;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Msg varchar2;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Keeperrorstack Boolean default false</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt">
				<span lang="EN-US" twffan="done">)</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">其中</span>
				<span lang="EN-US" twffan="done">num</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">是在</span>
				<span lang="EN-US" twffan="done">-20999</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">到</span>
				<span lang="EN-US" twffan="done">-20000</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">之间的任何数字（但事实上，</span>
				<span lang="EN-US" twffan="done">DBMS_OUPUT</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">和</span>
				<span lang="EN-US" twffan="done">DBMS_DESCRIBLE</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">包使用了</span>
				<span lang="EN-US" twffan="done">-20005</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">到</span>
				<span lang="EN-US" twffan="done">-20000</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">的数字）；</span>
				<span lang="EN-US" twffan="done">msg</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">是小于</span>
				<span lang="EN-US" twffan="done">2K</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">个字符的描述语，任何大于</span>
				<span lang="EN-US" twffan="done">2K</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">的字符都将被自动丢弃；</span>
				<span lang="EN-US" twffan="done">keeperrorstack</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">默认为</span>
				<span lang="EN-US" twffan="done">false</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">，是指清空异常栈，再将当前异常入栈，如果指定</span>
				<span lang="EN-US" twffan="done">true</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">的话就直接将当前异常压入栈中。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">    </span>CREATE OR REPLACE PROCEDURE raise_by_language (code_in IN PLS_INTEGER)</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">    </span>IS</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">       </span>l_message error_table.error_string%TYPE;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">    </span>BEGIN</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">       </span>SELECT error_string</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">         </span>INTO l_message</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">         </span>FROM error_table, v$nls_parameters v</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">        </span>WHERE error_number = code_in</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">          </span>AND string_language<span style="mso-spacerun: yes" twffan="done">  </span>= v.VALUE</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">          </span>AND v.parameter = 'NLS_LANGUAGE';</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">       </span>RAISE_APPLICATION_ERROR (code_in, l_message);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-spacerun: yes" twffan="done">    </span>END;</span>
		</p>
<img src ="http://www.cppblog.com/ivenher/aggbug/14132.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/ivenher/" target="_blank">爱饭盒</a> 2006-10-25 16:24 <a href="http://www.cppblog.com/ivenher/articles/14132.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle:pl/sql 异常处理（ 2 ） </title><link>http://www.cppblog.com/ivenher/articles/14131.html</link><dc:creator>爱饭盒</dc:creator><author>爱饭盒</author><pubDate>Wed, 25 Oct 2006 08:23:00 GMT</pubDate><guid>http://www.cppblog.com/ivenher/articles/14131.html</guid><wfw:comment>http://www.cppblog.com/ivenher/comments/14131.html</wfw:comment><comments>http://www.cppblog.com/ivenher/articles/14131.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/ivenher/comments/commentRss/14131.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/ivenher/services/trackbacks/14131.html</trackback:ping><description><![CDATA[
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">pl/sql</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">提供了强大而灵活的手段来捕捉和处理程序产生的异常，从而使</span>
				<span lang="EN-US" twffan="done">oracle</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">的用户远离一些令人烦恼的</span>
				<span lang="EN-US" twffan="done">bug</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /?><o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: center" align="center">
				<b>
						<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">异常定义</span>
						<span lang="EN-US" twffan="done">
								<o:p>
								</o:p>
						</span>
				</b>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: center" align="center">
				<b>
						<span lang="EN-US" twffan="done"> <o:p></o:p></span>
				</b>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">在一个异常产生、被捕获并处理之前，它必须被定义。</span>
				<span lang="EN-US" twffan="done">Oracle</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">定义了几千个异常，绝大多数只有错误编号和相关描述，仅仅命名了若干个最常被用到的异常。这些名字被储存在</span>
				<span lang="EN-US" twffan="done">STANDARD</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">，</span>
				<span lang="EN-US" twffan="done">UTL_FILE</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">，</span>
				<span lang="EN-US" twffan="done">DBMS_SQL</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">这几个系统包中，详情请见</span>
				<span lang="EN-US" twffan="done">oracle:pl/sql</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">异常处理（</span>
				<span lang="EN-US" twffan="done">1</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">）。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">出自之外的绝大多数异常需要程序员命名。有</span>
				<span lang="EN-US" twffan="done">2</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">种命名异常的方法：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">1</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">：声明一个自定义异常</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">在</span>
				<span lang="EN-US" twffan="done">STANDARD</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">中的命名了的异常基本山是与系统的错误相关的（当然那些只有</span>
				<span lang="EN-US" twffan="done">errorcode</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">的异常也是这样），但在实际的应用中我们经常需要与特定的应用程序相关的异常，由程序员声明的异常就是用于处理这种情况的。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">Oracle</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">异常处理模块的方便的地方在于，它并没有区别对待自定义的与预定义的异常。这使得我们可以像对待预定义异常一样，捕捉和处理自定义异常，只是在此之前需要声明它；同时对于一个自定义的异常，我们需要用</span>
				<span lang="EN-US" twffan="done">RAISE</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">来手动产生。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">下面是一个声明的例子：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>procedure calc_ammul_sales</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>(company_id_in in company.company_id%tye)</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>is</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>invalid_company_id exception;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>negative_balance excrption;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>duplicate_company Boolean;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>/*body of executable statement*/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>when invalid_company_id</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>then /*handle exception*/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>when no_data_found</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>then /*handle exception*/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>/*…..*/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>end;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">需要注意的是处理定义的时候，只有两个地方会出现自定义的异常：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt; mso-list: l1 level1 lfo4; tab-stops: list 21.0pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">ü<span style="FONT: 7pt 'Times New Roman'" twffan="done">         </span></span>
				<span lang="EN-US" twffan="done">raise exception</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">；</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt; mso-list: l1 level1 lfo4; tab-stops: list 21.0pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">ü<span style="FONT: 7pt 'Times New Roman'" twffan="done">         </span></span>
				<span lang="EN-US" twffan="done">when exception then</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">2</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">：为非预定义异常关联一个名字</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">仅仅</span>
				<span lang="EN-US" twffan="done">21</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">个预定义异常对我们来说实在是太少了，还有几千个异常只有</span>
				<span lang="EN-US" twffan="done">errorcode</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">和描述。另外，程序员也可以用</span>
				<span lang="EN-US" twffan="done">RAISE_APPLICATION_ERROR</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">定义一个含</span>
				<span lang="EN-US" twffan="done">errorcode</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">和描述的异常。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">当然，只用</span>
				<span lang="EN-US" twffan="done">errorcode</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">也可以很好地完成工作，只要你不担心会忘了那串数字代表的意思就行。比方说</span>
				<span lang="EN-US" twffan="done">;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>when others</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>then</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 3" twffan="done">                     </span>if sqlcode=-1843 then<span style="mso-spacerun: yes" twffan="done">  </span>/*sqlcode</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">是内建的用于返回最近一次错误编号的函数</span>
				<span lang="EN-US" twffan="done">*/</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>…..</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">这的确是一段让人感到晦涩的代码，还是给它关联个名字吧。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">我们要用到的是</span>
				<span lang="EN-US" twffan="done">pragma exception_init(exception,integer)</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">，然后就可以像对待预定义异常一样对待它了，我是说没必要像上面的那种一样用</span>
				<span lang="EN-US" twffan="done">raise</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">。</span>
				<span lang="EN-US" twffan="done">Exception_init</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">是一个编译时运行的函数，它只能出现在代码的声明部分，而异常名字必须在此之前被定义。下面用一个匿名过程举个例子：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>declare</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>invalid_company_id exception;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>pragma exception_init(invalid_company_id, -1834);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">要注意的时：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt; mso-list: l2 level1 lfo2; tab-stops: list 21.0pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">ü<span style="FONT: 7pt 'Times New Roman'" twffan="done">         </span></span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">不可以用</span>
				<span lang="EN-US" twffan="done">-1403</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">（</span>
				<span lang="EN-US" twffan="done">no_data_found</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">），用</span>
				<span lang="EN-US" twffan="done">100</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">，事实上</span>
				<span lang="EN-US" twffan="done">exception_init</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">中的</span>
				<span lang="EN-US" twffan="done">integer</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">对应的是</span>
				<span lang="EN-US" twffan="done">sqlcode</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">返回的值。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt; mso-list: l2 level1 lfo2; tab-stops: list 21.0pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">ü<span style="FONT: 7pt 'Times New Roman'" twffan="done">         </span></span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">不能为</span>
				<span lang="EN-US" twffan="done">0</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">，不能大于</span>
				<span lang="EN-US" twffan="done">100</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">，不能小于</span>
				<span lang="EN-US" twffan="done">-1000000</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">一个例子：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>procedure delete_company(company_id_in in number)</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>is</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>still_have_emplyee exception;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>pragma exception(still_have_employee, -2293);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>delete from compamy</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>where company_id=company_id_in;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>when still_have_employee</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>then dbms_output.put_line(‘delete employees for company first’);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>end;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">在一下两种情况下，我们有必要使用</span>
				<span lang="EN-US" twffan="done">exception_init</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt; mso-list: l0 level1 lfo3; tab-stops: list 21.0pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">ü<span style="FONT: 7pt 'Times New Roman'" twffan="done">         </span></span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">一个非预定义异常是经常要被用到的。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; TEXT-INDENT: -21pt; mso-list: l0 level1 lfo3; tab-stops: list 21.0pt">
				<span lang="EN-US" style="FONT-FAMILY: Wingdings" twffan="done">ü<span style="FONT: 7pt 'Times New Roman'" twffan="done">         </span></span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">我们将用</span>
				<span lang="EN-US" twffan="done">raise_applocation_error</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">产生了一个自定义的</span>
				<span lang="EN-US" twffan="done">errorcode</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">时。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">一种简便的方法是将以上两种情况中的异常定义在一个包中，这样我们就没有必要每次都重复定义了。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Create or replace package dynsql</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Is</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Invalid_table_name exception;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Pragma exception_init(invalid_table_name, -903);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Invalid_column_name exception;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Pragma exception_init(invalid_column_name, -904);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>En_too_young const number:=-200001;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Exc_too_young exception;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Pragma exception_init(exc_too_young, -20001);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>End;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">有了上面这个包，就可以方便的处理异常了</span>
				<span lang="EN-US" twffan="done">;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>procedure validate_emp(birthdate in date)</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>is</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>min_tear const pls_integer:=18;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>begin</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>if add_month(sysdate,min_year*12*-1)&lt;birthdate_in</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>then</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 63pt">
				<span lang="EN-US" twffan="done">raise_application_error(dynsql.en_too_young, ‘employee must be’ || min_year ||‘old’);</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 2" twffan="done">              </span>end if;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>end;</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">除了</span>
				<span lang="EN-US" twffan="done">standard</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">包中的</span>
				<span lang="EN-US" twffan="done">21</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">个预定义异常外，还有一些包也定义了一些异常。但与</span>
				<span lang="EN-US" twffan="done">standard</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">包中异常不同的是，在使用这些异常时，需要带上包的名字。如：</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>when dbms_lob.invalid_argval then ……</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done"> <o:p></o:p></span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">非常有用的一点是，可以在最外层的</span>
				<span lang="EN-US" twffan="done">pl/sql</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">块的异常处理模块中加入</span>
				<span lang="EN-US" twffan="done">others</span>
				<span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'" twffan="done">，这样就可以把从内部传递出来的未被处理的剩余异常全部处理掉了。</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>Exception</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>When others</span>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
				<span lang="EN-US" twffan="done">
						<span style="mso-tab-count: 1" twffan="done">       </span>
						<span style="mso-tab-count: 1" twffan="done">       </span>Then ….</span>
		</p>
<img src ="http://www.cppblog.com/ivenher/aggbug/14131.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/ivenher/" target="_blank">爱饭盒</a> 2006-10-25 16:23 <a href="http://www.cppblog.com/ivenher/articles/14131.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Oracle:pl/sql 异常处理（ 1 ）</title><link>http://www.cppblog.com/ivenher/articles/14130.html</link><dc:creator>爱饭盒</dc:creator><author>爱饭盒</author><pubDate>Wed, 25 Oct 2006 08:17:00 GMT</pubDate><guid>http://www.cppblog.com/ivenher/articles/14130.html</guid><wfw:comment>http://www.cppblog.com/ivenher/comments/14130.html</wfw:comment><comments>http://www.cppblog.com/ivenher/articles/14130.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/ivenher/comments/commentRss/14130.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/ivenher/services/trackbacks/14130.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: pl/sql				提供了强大而灵活的手段来捕捉和处理程序产生的异常，从而使				oracle				的用户远离一些令人烦恼的				bug				。								 														pl/sql														异常处理的概念和术语																															...&nbsp;&nbsp;<a href='http://www.cppblog.com/ivenher/articles/14130.html'>阅读全文</a><img src ="http://www.cppblog.com/ivenher/aggbug/14130.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/ivenher/" target="_blank">爱饭盒</a> 2006-10-25 16:17 <a href="http://www.cppblog.com/ivenher/articles/14130.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>ORACLE之常用FAQ V1.0 (4)  第四部分、性能调整</title><link>http://www.cppblog.com/ivenher/articles/13153.html</link><dc:creator>爱饭盒</dc:creator><author>爱饭盒</author><pubDate>Fri, 29 Sep 2006 09:26:00 GMT</pubDate><guid>http://www.cppblog.com/ivenher/articles/13153.html</guid><wfw:comment>http://www.cppblog.com/ivenher/comments/13153.html</wfw:comment><comments>http://www.cppblog.com/ivenher/articles/13153.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/ivenher/comments/commentRss/13153.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/ivenher/services/trackbacks/13153.html</trackback:ping><description><![CDATA[
		<span class="tpc_content" twffan="done">
				<b>第四部分、性能调整</b>
				<br />
				<font color="red">[Q]如果设置自动跟踪</font>
				<br />[A]用system登录<br />执行$ORACLE_HOME/rdbms/admin/utlxplan.sql创建计划表<br />执行$ORACLE_HOME/sqlplus/admin/plustrce.sql创建plustrace角色<br />如果想计划表让每个用户都能使用，则<br />SQL&gt;create public synonym plan_table for plan_table;<br />SQL&gt; grant all on plan_table to public;<br />如果想让自动跟踪的角色让每个用户都能使用，则<br />SQL&gt; grant plustrace to public;<br />通过如下语句开启/停止跟踪<br />SET AUTOTRACE ON |OFF <br />| ON EXPLAIN | ON STATISTICS | TRACEONLY | TRACEONLY EXPLAIN<br /><font color="red">[Q]如果跟踪自己的会话或者是别人的会话</font><br />[A]跟踪自己的会话很简单<br />Alter session set sql_trace true|false<br />Or<br />Exec dbms_session.set_sql_trace(TRUE);<br />如果跟踪别人的会话，需要调用一个包<br />exec dbms_system.set_sql_trace_in_session(sid,serial#,true|false)<br />跟踪的信息在user_dump_dest 目录下可以找到或通过如下脚本获得文件名称（适用于Win环境，如果是unix需要做一定修改）<br />SELECT p1.value||'\'||p2.value||'_ora_'||p.spid||'.ora' filename<br />FROM<br />v$process p,<br />v$session s,<br />v$parameter p1,<br />v$parameter p2<br />WHERE p1.name = 'user_dump_dest'<br />AND p2.name = 'db_name'<br />AND p.addr = s.paddr<br />AND s.audsid = USERENV ('SESSIONID')<br />最后，可以通过Tkprof来解析跟踪文件，如<br />Tkprof 原文件 目标文件 sys=n<br /><font color="red">[Q]怎么设置整个数据库系统跟踪</font><br />[A]其实文档上的alter system set sql_trace=true是不成功的<br />但是可以通过设置事件来完成这个工作，作用相等<br />alter system set events<br />'10046 trace name context forever,level 1';<br />如果关闭跟踪，可以用如下语句<br />alter system set events<br />'10046 trace name context off';<br />其中的level 1与上面的8都是跟踪级别<br />level 1：跟踪SQL语句，等于sql_trace=true<br />level 4：包括变量的详细信息<br />level 8：包括等待事件<br />level 12：包括绑定变量与等待事件<br /><font color="red">[Q]怎么样根据OS进程快速获得DB进程信息与正在执行的语句</font><br />[A]有些时候，我们在OS上操作，象TOP之后我们得到的OS进程，怎么快速根据OS信息获得DB信息呢？<br />我们可以编写如下脚本：<br />$more whoit.sh<br />#!/bin/sh<br />sqlplus /nolog 100,cascade=&gt; TRUE);<br />dbms_stats.gather_table_stats(User,TableName,degree =&gt; 4,cascade =&gt; true);<br />这是对命令与工具包的一些总结<br />1、对于分区表，建议使用DBMS_STATS，而不是使用Analyze语句。 <br />a) 可以并行进行，对多个用户，多个Table <br />b) 可以得到整个分区表的数据和单个分区的数据。 <br />c) 可以在不同级别上Compute Statistics：单个分区，子分区，全表，所有分区 <br />d) 可以倒出统计信息 <br />e) 可以用户自动收集统计信息 <br />2、DBMS_STATS的缺点 <br />a) 不能Validate Structure <br />b) 不能收集CHAINED ROWS, 不能收集CLUSTER TABLE的信息，这两个仍旧需要使用Analyze语句。 <br />c) DBMS_STATS 默认不对索引进行Analyze，因为默认Cascade是False，需要手工指定为True <br />3、对于oracle 9里面的External Table，Analyze不能使用，只能使用DBMS_STATS来收集信息。<br /><font color="red">[Q]怎么样快速重整索引</font><br />[A]通过rebuild语句，可以快速重整或移动索引到别的表空间<br />rebuild有重建整个索引数的功能，可以在不删除原始索引的情况下改变索引的存储参数<br />语法为<br />alter index index_name rebuild tablespace ts_name<br />storage(……);<br />如果要快速重建整个用户下的索引，可以用如下脚本，当然，需要根据你自己的情况做相应修改<br />SQL&gt; set heading off<br />SQL&gt; set feedback off<br />SQL&gt; spool d:\index.sql<br />SQL&gt; SELECT 'alter index ' || index_name || ' rebuild '<br />||'tablespace INDEXES storage(initial 256K next 256K pctincrease 0);'<br />FROM all_indexes<br />WHERE ( tablespace_name != 'INDEXES'<br />OR next_extent != ( 256 * 1024 )<br />)<br />AND owner = USER<br />SQL&gt;spool off<br />另外一个合并索引的语句是<br />alter index index_name coalesce，这个语句仅仅是合并索引中同一级的leaf block<br />消耗不大，对于有些索引中存在大量空间浪费的情况下，有一些作用。<br /><font color="red">[Q]如何使用Hint提示</font><br />[A] 在select/delete/update后写/*+ hint */<br />如 select /*+ index(TABLE_NAME INDEX_NAME) */ col1...<br />注意/*和+之间不能有空格<br />如用hint指定使用某个索引<br />select /*+ index(cbotab) */ col1 from cbotab;<br />select /*+ index(cbotab cbotab1) */ col1 from cbotab;<br />select /*+ index(a cbotab1) */ col1 from cbotab a;<br />其中<br />TABLE_NAME是必须要写的，且如果在查询中使用了表的别名，在hint也要用表的别名来代替表名;<br />INDEX_NAME可以不必写，Oracle会根据统计值选一个索引;<br />如果索引名或表名写错了，那这个hint就会被忽略;<br /><font color="red">[Q]怎么样快速复制表或者是插入数据</font><br />[A]快速复制表可以指定Nologging选项<br />如：Create table t1 nologging <br />as select * from t2;<br />快速插入数据可以指定append提示，但是需要注意<br />noarchivelog模式下，默认用了append就是nologging模式的。 <br />在archivelog下，需要把表设置程Nologging模式。<br />如insert /*+ append */ into t1 <br />select * from t2<br />注意：如果在9i环境中并设置了FORCE LOGGING，则以上操作是无效的，并不会加快，当然，可以通过如下语句设置为NO FORCE LOGGING。<br />Alter database no force logging;<br />是否开启了FORCE LOGGING，可以用如下语句查看<br />SQL&gt; select force_logging from v$database;<br /><font color="red">[Q]怎么避免使用特定索引</font><br />[A]在很多时候，Oracle会错误的使用索引而导致效率的明显下降，我们可以使用一点点技巧而避免使用不该使用的索引，如：<br />表test,有字段a,b,c,d，在a,b,c上建立联合索引inx_a(a,b,c)，在b上单独建立了一个索引Inx_b(b)。<br />在正常情况下，where a=? and b=? and c=?会用到索引inx_a，<br />where b=?会用到索引inx_b<br />但是，where a=? and b=? and c=? group by b会用到哪个索引呢？在分析数据不正确（很长时间没有分析）或根本没有分析数据的情况下，oracle往往会使用索引inx_b。通过执行计划的分析，这个索引的使用，将大大耗费查询时间。<br />当然，我们可以通过如下的技巧避免使用inx_b，而使用inx_a。<br />where a=? and b=? and c=? group by b||'' --如果b是字符<br />where a=? and b=? and c=? group by b+0 --如果b是数字<br />通过这样简单的改变，往往可以是查询时间提交很多倍<br />当然，我们也可以使用no_index提示，相信很多人没有用过，也是一个不错的方法：<br />select /*+ no_index(t,inx_b) */ * from test t<br />where a=? and b=? and c=? group by b<br /><font color="red">[Q]Oracle什么时候会使用跳跃式索引扫描</font><br />[A]这是9i的一个新特性跳跃式索引扫描(Index Skip Scan).<br />例如表有索引index(a,b,c)，当查询条件为<br />where b=?的时候，可能会使用到索引index(a,b,c)<br />如，执行计划中出现如下计划：<br />INDEX (SKIP SCAN) OF 'TEST_IDX' (NON-UNIQUE)<br />Oracle的优化器(这里指的是CBO)能对查询应用Index Skip Scans至少要有几个条件:<br />1 优化器认为是合适的。<br />2 索引中的前导列的唯一值的数量能满足一定的条件（如重复值很多）。<br />3 优化器要知道前导列的值分布(通过分析/统计表得到)。<br />4 合适的SQL语句<br />等。<br /><font color="red">[Q]怎么样创建使用虚拟索引</font><br />[A]可以使用nosegment选项，如<br />create index virtual_index_name on table_name(col_name) nosegment;<br />如果在哪个session需要测试虚拟索引，可以利用隐含参数来处理<br />alter session set "_use_nosegment_indexes" = true;<br />就可以利用explain plan for select ……来看虚拟索引的效果<br />利用@$ORACLE_HOME/rdbms/admin/utlxpls查看执行计划<br />最后，根据需要，我们可以删除虚拟索引，如普通索引一样<br />drop index virtual_index_name;<br />注意：虚拟索引并不是物理存在的，所以虚拟索引并不等同于物理索引，不要用自动跟踪去测试虚拟索引，因为那是实际执行的效果，是用不到虚拟索引的。<br /><font color="red">[Q]怎样监控无用的索引</font><br />[A]Oracle 9i以上，可以监控索引的使用情况，如果一段时间内没有使用的索引，一般就是无用的索引<br />语法为：<br />开始监控：alter index index_name monitoring usage;<br />检查使用状态：select * from v$object_usage;<br />停止监控：alter index index_name nomonitoring usage;<br />当然，如果想监控整个用户下的索引，可以采用如下的脚本：<br />set heading off<br />set echo off<br />set feedback off<br />set pages 10000<br />spool start_index_monitor.sql<br />SELECT 'alter index '||owner||'.'||index_name||' monitoring usage;'<br />FROM dba_indexes<br />WHERE owner = USER; <br />spool off <br />set heading on<br />set echo on<br />set feedback on<br />------------------------------------------------<br />set heading off<br />set echo off<br />set feedback off<br />set pages 10000<br />spool stop_index_monitor.sql<br />SELECT 'alter index '||owner||'.'||index_name||' nomonitoring usage;'<br />FROM dba_indexes<br />WHERE owner = USER; <br />spool off <br />set heading on<br />set echo on<br />set feedback on<br /><font color="red">[Q]怎么样能固定我的执行计划</font><br />[A]可以使用OUTLINE来固定SQL语句的执行计划<br />用如下语句可以创建一个OUTLINE<br />Create oe replace outline OutLn_Name on<br />Select Col1,Col2 from Table<br />where ……<br />如果要删除Outline，可以采用<br />Drop Outline OutLn_Name;<br />对于已经创建了的OutLine，存放在OUTLN用户的OL$HINTS表下面<br />对于有些语句，你可以使用update outln.ol$hints来更新outline<br />如update outln.ol$hints(ol_name,'TEST1','TEST2','TEST2','TEST1)<br />where ol_name in ('TEST1','TEST2');<br />这样，你就把Test1 OUTLINE与Test2 OUTLINE互换了<br />如果想利用已经存在的OUTLINE，需要设置以下参数<br />Alter system/session set Query_rewrite_enabled = true<br />Alter system/session set use_stored_outlines = true<br /><font color="red">[Q]v$sysstat中的class分别代表什么</font><br />[A]统计类别<br />1 代表事例活动<br />2 代表Redo buffer活动<br />4 代表锁<br />8 代表数据缓冲活动<br />16 代表OS活动<br />32 代表并行活动<br />64 代表表访问<br />128 代表调试信息<br /><font color="red">[Q]怎么杀掉特定的数据库会话</font><br />[A] Alter system kill session 'sid,serial#';<br />或者<br />alter system disconnect session 'sid,serial#' immediate;<br />在win上，还可以采用oracle提供的orakill杀掉一个线程（其实就是一个Oracle进程）<br />在Linux/Unix上，可以直接利用kill杀掉数据库进程对应的OS进程<br /><font color="red">[Q]怎么快速查找锁与锁等待</font><br />[A]数据库的锁是比较耗费资源的，特别是发生锁等待的时候，我们必须找到发生等待的锁，有可能的话，杀掉该进程。<br />这个语句将查找到数据库中所有的DML语句产生的锁，还可以发现，任何DML语句其实产生了两个锁，一个是表锁，一个是行锁。<br />可以通过alter system kill session ‘sid,serial#’来杀掉会话<br />SELECT /*+ rule */ s.username,<br />decode(l.type,'TM','TABLE LOCK',<br />'TX','ROW LOCK',<br />NULL) LOCK_LEVEL,<br />o.owner,o.object_name,o.object_type,<br />s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser<br />FROM v$session s,v$lock l,dba_objects o<br />WHERE l.sid = s.sid<br />AND l.id1 = o.object_id(+)<br />AND s.username is NOT NULL<br />如果发生了锁等待，我们可能更想知道是谁锁了表而引起谁的等待<br />以下的语句可以查询到谁锁了表，而谁在等待。<br />SELECT /*+ rule */ lpad(' ',decode(l.xidusn ,0,3,0))||l.oracle_username User_name,<br />o.owner,o.object_name,o.object_type,s.sid,s.serial#<br />FROM v$locked_object l,dba_objects o,v$session s<br />WHERE l.object_id=o.object_id<br />AND l.session_id=s.sid<br />ORDER BY o.object_id,xidusn DESC<br />以上查询结果是一个树状结构，如果有子节点，则表示有等待发生。如果想知道锁用了哪个回滚段，还可以关联到V$rollname，其中xidusn就是回滚段的USN<br /><font color="red">[Q] 如何有效的删除一个大表(extent数很多的表)</font><br />[A] 一个有很多(100k)extent的表，如果只是简单地用drop table的话，会很大量消耗CPU（Oracle要对fet$、uet$数据字典进行操作），可能会用上几天的时间，较好的方法是分多次删除extent，以减轻这种消耗：<br />1. truncate table big-table reuse storage;<br />2. alter table big-table deallocate unused keep 2000m ( 原来大小的n-1/n);<br />3. alter table big-table deallocate unused keep 1500m ;<br />....<br />4. drop table big-table;<br /><font color="red">[Q]如何收缩临时数据文件的大小</font><br />[A]9i以下版本采用<br />ALTER DATABASE DATAFILE 'file name' RESIZE 100M类似的语句<br />9i以上版本采用<br />ALTER DATABASE TEMPFILE 'file name' RESIZE 100M<br />注意，临时数据文件在使用时，一般不能收缩，除非关闭数据库或断开所有会话，停止对临时数据文件的使用。<br /><font color="red">[Q]怎么清理临时段</font><br />[A]可以使用如下办法<br />1、 使用如下语句查看一下认谁在用临时段<br />SELECT username,sid,serial#,sql_address,machine,program,<br />tablespace,segtype, contents <br />FROM v$session se,v$sort_usage su<br />WHERE se.saddr=su.session_addr <br />2、 那些正在使用临时段的进程<br />SQL&gt;Alter system kill session 'sid,serial#';<br />3、把TEMP表空间回缩一下<br />SQL&gt;Alter tablespace TEMP coalesce;<br />还可以使用诊断事件<br />1、 确定TEMP表空间的ts#<br />SQL&gt; select ts#, name FROM v$tablespace;<br />TS# NAME <br />----------------------- <br />0 SYSYEM <br />1 RBS <br />2 USERS <br />3* TEMP <br />……<br />2、 执行清理操作<br />alter session set events 'immediate trace name DROP_SEGMENTS level TS#+1'<br />说明： <br />temp表空间的TS# 为 3*, So TS#+ 1= 4<br />如果想清除所有表空间的临时段，则 <br />TS# = 2147483647<br /><font color="red">[Q]怎么样dump数据库内部结构，如上面显示的控制文件的结构</font><br />[A]常见的有<br />1、分析数据文件块，转储数据文件n的块m<br />alter system dump datafile n block m<br />2、分析日志文件<br />alter system dump logfile logfilename;<br />3、分析控制文件的内容<br />alter session set events 'immediate trace name CONTROLF level 10'<br />4、分析所有数据文件头<br />alter session set events 'immediate trace name FILE_HDRS level 10'<br />5、分析日志文件头<br />alter session set events 'immediate trace name REDOHDR level 10'<br />6、分析系统状态，最好每10分钟一次，做三次对比<br />alter session set events 'immediate trace name SYSTEMSTATE level 10'<br />7、分析进程状态<br />alter session set events 'immediate trace name PROCESSSTATE level 10'<br />8、分析Library Cache的详细情况<br />alter session set events 'immediate trace name library_cache level 10'<br /><font color="red">[Q]如何获得所有的事件代码</font><br />[A] 事件代码范围一般从10000 to 10999，以下列出了这个范围的事件代码与信息<br />SET SERVEROUTPUT ON<br />DECLARE <br />err_msg VARCHAR2(120);<br />BEGIN<br />dbms_output.enable (1000000);<br />FOR err_num IN 10000..10999<br />LOOP<br />err_msg := SQLERRM (-err_num);<br />IF err_msg NOT LIKE '%Message '||err_num||' not found%' THEN<br />dbms_output.put_line (err_msg);<br />END IF;<br />END LOOP;<br />END;<br />/<br />在Unix系统上，事件信息放在一个文本文件里 <br />$ORACLE_HOME/rdbms/mesg/oraus.msg<br />可以用如下脚本查看事件信息 <br />event=10000<br />while [ $event -ne 10999 ]<br />do<br />event=`expr $event + 1`<br />oerr ora $event<br />done<br />对于已经确保的/正在跟踪的事件，可以用如下脚本获得<br />SET SERVEROUTPUT ON<br />DECLARE<br />l_level NUMBER;<br />BEGIN<br />FOR l_event IN 10000..10999<br />LOOP<br />dbms_system.read_ev (l_event,l_level);<br />IF l_level &gt; 0 THEN<br />dbms_output.put_line ('Event '||TO_CHAR (l_event)||<br />' is set at level '||TO_CHAR (l_level));<br />END IF;<br />END LOOP;<br />END;<br />/<br /><font color="red">[Q]什么是STATSPACK，我怎么使用它？</font><br />[A]Statspack是Oracle 8i以上提供的一个非常好的性能监控与诊断工具，基本上全部包含了BSTAT/ESTAT的功能，更多的信息<br />可以参考附带文档$ORACLE_HOME/rdbms/admin/spdoc.txt。 <br />安装Statspack: <br />cd $ORACLE_HOME/rdbms/admin<br />sqlplus "/ as sysdba" @spdrop.sql -- 卸载，第一次可以不需要<br />sqlplus "/ as sysdba" @spcreate.sql -- 需要根据提示输入表空间名<br />使用Statspack: <br />sqlplus perfstat/perfstat<br />exec statspack.snap; -- 进行信息收集统计，每次运行都将产生一个快照号<br />-- 获得快照号，必须要有两个以上的快照，才能生成报表<br />select SNAP_ID, SNAP_TIME from STATS$SNAPSHOT; <br />@spreport.sql -- 输入需要查看的开始快照号与结束快照号<br />其他相关脚本s: <br />spauto.sql - 利用dbms_job提交一个作业，自动的进行STATPACK的信息收集统计 <br />sppurge.sql - 清除一段范围内的统计信息，需要提供开始快照与结束快照号<br />sptrunc.sql - 清除(truncate)所有统计信息</span>
		<br />
		<!---->
		<!---->
		<!---->
		<br />
<img src ="http://www.cppblog.com/ivenher/aggbug/13153.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/ivenher/" target="_blank">爱饭盒</a> 2006-09-29 17:26 <a href="http://www.cppblog.com/ivenher/articles/13153.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>ORACLE之常用FAQ V1.0 (5)  第五部分、ORACLE网络与安全</title><link>http://www.cppblog.com/ivenher/articles/13154.html</link><dc:creator>爱饭盒</dc:creator><author>爱饭盒</author><pubDate>Fri, 29 Sep 2006 09:26:00 GMT</pubDate><guid>http://www.cppblog.com/ivenher/articles/13154.html</guid><wfw:comment>http://www.cppblog.com/ivenher/comments/13154.html</wfw:comment><comments>http://www.cppblog.com/ivenher/articles/13154.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/ivenher/comments/commentRss/13154.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/ivenher/services/trackbacks/13154.html</trackback:ping><description><![CDATA[
		<span class="tpc_content" twffan="done">
				<b>第五部分、ORACLE网络与安全</b>
				<br />
				<font color="red">[Q]如何限定特定IP访问数据库</font>
				<br />[A]可以利用登录触发器、cmgw或者是在$OREACLE_HOME/network/admin下新增一个protocol.ora文件（有些os可能是. protocol.ora），9i可以直接修改sqlnet.ora：<br />增加如下内容：<br />tcp.validnode_checking=yes<br />#允许访问的ip<br />tcp.inited_nodes=(ip1,ip2,……)<br />#不允许访问的ip<br />tcp.excluded_nodes=(ip1,ip2,……)<br /><font color="red">[Q]如何穿过防火墙连接数据库</font><br />[A]这个问题只会在WIN平台出现，UNIX平台会自动解决。<br />解决方法：<br />在服务器端的SQLNET.ORA应类似<br />SQLNET.AUTHENTICATION_SERVICES= (NTS) <br />NAMES.DIRECTORY_PATH= (TNSNAMES, ONAMES, HOSTNAME) <br />TRACE_LEVEL_CLIENT = 16 <br />注册表的HOME0加[HKEY_LOCAL_MACHINE] <br />USE_SHARED_SOCKET=TRUE<br /><font color="red">[Q]如何利用hostname方式连接数据库</font><br />host name方式只支持tcp/ip协议的小局域网<br />修改listener.ora中的如下信息<br />(SID_DESC =<br />(GLOBAL_DBNAME = ur_hostname) --你的机器名<br />(ORACLE_HOME = E:\oracle\ora92) --oracle home<br />(SID_NAME = orcl) --sid name<br />)<br />然后在客户端<br />的sqlnet.ora中，确保有<br />NAMES.DIRECTORY_PATH= (HOSTNAME)<br />你就可以利用数据库服务器的名称访问数据库了<br /><font color="red">[Q]dbms_repcat_admin能带来什么安全隐患</font><br />[A]如果一个用户能执行dbms_repcat_admin包，将获得极大的系统权限。<br />以下情况可能获得该包的执行权限：<br />1、在sys下grant execute on dbms_repcat_admin to public[|user_name]<br />2、用户拥有execute any procedure特权（仅限于9i以下，9i必须显示授权）<br />如果用户通过执行如下语句：<br />exec sys.dbms_repcat_admin.grant_admin_any_schema('user_name');<br />该用户将获得极大的系统特权<br />可以从user_sys_privs中获得详细信息<br /><font color="red">[Q]在不知道用户密码的时候，怎么样跳转到另外一个用户执行操作后并不影响该用户?</font><br />[A]我们通过如下的方法，可以安全使用该用户，然后再跳转回来，在某些时候比较有用<br />需要Alter user权限或DBA权限：<br />SQL&gt; select password from dba_users where username='SCOTT';<br />PASSWORD<br />-----------------------------<br />F894844C34402B67<br />SQL&gt; alter user scott identified by lion;<br />User altered.<br />SQL&gt; connect scott/lion<br />Connected.<br />REM Do whatever you like...<br />SQL&gt; connect system/manager<br />Connected.<br />SQL&gt; alter user scott identified by values 'F894844C34402B67';<br />User altered.<br />SQL&gt; connect scott/tiger<br />Connected.<br /><font color="red">[Q]如何加固你的数据库</font><br />[A]要注意以下方面<br />1. 修改sys, system的口令。 <br />2. Lock，修改，删除默认用户： dbsnmp,ctxsys等。 <br />3. 把REMOTE_OS_AUTHENT改成False，防止远程机器直接登陆。 <br />4. 把O7_DICTIONARY_ACCESSIBILITY改成False。 <br />5. 把一些权限从PUBLIC Role取消掉。 <br />6. 检查数据库的数据文件的安全性。不要设置成666之类的。检查其他dba 用户。 <br />7. 把一些不需要的服务（比如ftp, nfs等关闭掉） <br />8. 限制数据库主机上面的用户数量。 <br />9. 定期检查Metalink/OTN上面的security Alert。比如：<br /><a href="http://otn.oracle.com/deploy/security/alerts.htm" target="_blank"><font color="#003366">http://otn.oracle.com/deploy/security/alerts.htm</font></a><br /><br />10. 把你的数据库与应用放在一个单独的子网中，要不然你的用户密码很容易被sniffer去。或者采用advance security，对用户登录加密。 <br />11. 限止只有某些ip才能访问你的数据库。 <br />12. lsnrctl 要加密码，要不然别人很容易从外面关掉你的listener。 <br />13. 如果可能，不要使用默认1521端口<br /><font color="red">[Q]如何检查用户是否用了默认密码</font><br /><br />[A]如果使用默认密码，很可能就对你的数据库造成一定的安全隐患，那么可以使用如下的查询获得那些用户使用默认密码<br />select username "User(s) with Default Password!" <br />from dba_users <br />where password in <br />('E066D214D5421CCC', -- dbsnmp <br />'24ABAB8B06281B4C', -- ctxsys <br />'72979A94BAD2AF80', -- mdsys <br />'C252E8FA117AF049', -- odm <br />'A7A32CD03D3CE8D5', -- odm_mtr <br />'88A2B2C183431F00', -- ordplugins <br />'7EFA02EC7EA6B86F', -- ordsys <br />'4A3BA55E08595C81', -- outln <br />'F894844C34402B67', -- scott <br />'3F9FBD883D787341', -- wk_proxy <br />'79DF7A1BD138CF11', -- wk_sys <br />'7C9BA362F8314299', -- wmsys <br />'88D8364765FCE6AF', -- xdb <br />'F9DA8977092B7B81', -- tracesvr <br />'9300C0977D7DC75E', -- oas_public <br />'A97282CE3D94E29E', -- websys <br />'AC9700FD3F1410EB', -- lbacsys <br />'E7B5D92911C831E1', -- rman <br />'AC98877DE1297365', -- perfstat <br />'66F4EF5650C20355', -- exfsys <br />'84B8CBCA4D477FA3', -- si_informtn_schema <br />'D4C5016086B2DC6A', -- sys <br />'D4DF7931AB130E37') -- system <br />/<br /><font color="red">[Q]如何修改默认的XDB监听端口</font><br /><br />[A] Oracle9i默认的XML DB把HTTP的默认端口设为8080，这是一个太常用的端口了，很多别的WebServer都会使用这个端口，<br />如果我们安装了它，最好修改一下，避免冲突，如果不使用呢，就最好不要安装<br />提供三种修改的方法<br />1.dbca，选择你的数据库，然后Standard Database Features-&gt;Customize-&gt;Oracle XML DB option，进入这个画面你应该就知道怎么改了。 <br />2.OEM console，在XML Database 的配置里面修改 <br />3.用oracle提供的包： <br />-- 把HTTP/WEBDAV端口从8080改到8081 <br />SQL&gt; call dbms_xdb.cfg_update(updateXML(dbms_xdb.cfg_get(), <br />'/xdbconfig/sysconfig/protocolconfig/httpconfig/http-port/text()',8081)) <br />/ <br />-- 把FTP端口从2100改到2111 <br />SQL&gt; call dbms_xdb.cfg_update(updateXML(dbms_xdb.cfg_get(), <br />'/xdbconfig/sysconfig/protocolconfig/ftpconfig/ftp-port/text()',2111)) <br />/ <br />SQL&gt; commit; <br />SQL&gt; exec dbms_xdb.cfg_refresh; <br />-- 检查修改是否已经成功 <br />SQL&gt; select dbms_xdb.cfg_get from dual;<br /><font color="red">[Q]怎么捕获用户登录信息，如SID，IP地址等</font><br />[A]可以利用登录触发器，如<br />CREATE OR REPLACE TRIGGER tr_login_record<br />AFTER logon ON DATABASE<br />DECLARE<br />miUserSid NUMBER;<br />mtSession v$session%ROWTYPE;<br />CURSOR cSession(iiUserSid IN NUMBER) IS<br />SELECT * FROM v$session<br />WHERE sid=iiUserSid;<br />BEGIN<br />SELECT sid INTO miUserSid FROM v$mystat WHERE rownum</span>
		<br />
		<!---->
		<!---->
		<!---->
<img src ="http://www.cppblog.com/ivenher/aggbug/13154.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/ivenher/" target="_blank">爱饭盒</a> 2006-09-29 17:26 <a href="http://www.cppblog.com/ivenher/articles/13154.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>ORACLE之常用FAQ V1.0 (2) 第二部分、ORACLE构架体系</title><link>http://www.cppblog.com/ivenher/articles/13151.html</link><dc:creator>爱饭盒</dc:creator><author>爱饭盒</author><pubDate>Fri, 29 Sep 2006 09:24:00 GMT</pubDate><guid>http://www.cppblog.com/ivenher/articles/13151.html</guid><wfw:comment>http://www.cppblog.com/ivenher/comments/13151.html</wfw:comment><comments>http://www.cppblog.com/ivenher/articles/13151.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/ivenher/comments/commentRss/13151.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/ivenher/services/trackbacks/13151.html</trackback:ping><description><![CDATA[
		<span class="tpc_content" twffan="done">
				<b>第二部分、ORACLE构架体系</b>
				<br />
				<font color="red">[Q]ORACLE的有那些数据类型</font>
				<br />[A]常见的数据类型有<br />CHAR固定长度字符域，最大长度可达2000个字节 <br />NCHAR多字节字符集的固定长度字符域，长度随字符集而定，最多为2000个字符或2000个字节 <br />VARCHAR2可变长度字符域，最大长度可达4000个字符 <br />NVARCHAR2多字节字符集的可变长度字符域，长度随字符集而定，最多为4000个字符或4000个字节 <br />DATE用于存储全部日期的固定长度(7个字节)字符域，时间作为日期的一部分存储其中。除非 <br />通过设置init.ora文件的NLS_DATE_FORMAT参数来取代日期格式，否则查询时，日期以 <br />DD-MON-YY格式表示，如13-APR-99表示1999.4.13 <br />NUMBER可变长度数值列，允许值为0、正数和负数。NUMBER值通常以4个字节或更少的字节存储，最多21字节 <br />LONG可变长度字符域，最大长度可到2GB <br />RAW表示二进制数据的可变长度字符域，最长为2000个字节 <br />LONGRAW表示二进制数据的可变长度字符域，最长为2GB <br />MLSLABEL只用于TrustedOracle，这个数据类型每行使用2至5个字节 <br />BLOB二进制大对象，最大长度为4GB <br />CLOB字符大对象，最大长度为4GB <br />NCLOB多字节字符集的CLOB数据类型，最大长度为4GB <br />BFILE外部二进制文件，大小由操作系统决定 <br />ROWID表示RowID的二进制数据，Oracle8RowID的数值为10个字节，在Oracle7中使用的限定 <br />RowID格式为6个字节 <br />UROWID用于数据寻址的二进制数据，最大长度为4000个字节 <br /><font color="red">[Q]Oracle有哪些常见关键字，不能被用于对象名</font><br />[A]以8i版本为例，一般保留关键字不能用做对象名<br />ACCESS ADD ALL ALTER AND ANY AS ASC AUDIT BETWEEN BY CHAR CHECK CLUSTER COLUMN COMMENT COMPRESS CONNECT CREATE CURRENT DATE DECIMAL DEFAULT DELETE DESC DISTINCT DROP ELSE EXCLUSIVE EXISTS FILE FLOAT FOR FROM GRANT GROUP HAVING IDENTIFIED IMMEDIATE IN INCREMENT INDEX INITIAL INSERT INTEGER INTERSECT INTO IS LEVEL LIKE LOCK LONG MAXEXTENTS MINUS MLSLABEL MODE MODIFY NOAUDIT NOCOMPRESS NOT NOWAIT NULL NUMBER OF OFFLINE ON ONLINE OPTION OR ORDER PCTFREE PRIOR PRIVILEGES PUBLIC RAW RENAME RESOURCE REVOKE ROW ROWID ROWNUM ROWS SELECT SESSION SET SHARE SIZE SMALLINT START SUCCESSFUL SYNONYM SYSDATE TABLE THEN TO TRIGGER UID UNION UNIQUE UPDATE USER VALIDATE VALUES VARCHAR VARCHAR2 VIEW WHENEVER WHERE WITH<br />详细信息可以查看v$reserved_words视图<br /><font color="red">[Q]怎么查看数据库版本</font><br />[A]select * from v$version<br />包含版本信息，核心版本信息，位数信息(32位或64位)等<br />至于位数信息，在linux/unix平台上，可以通过file查看，如<br />file $ORACLE_HOME/bin/oracle<br /><font color="red">[Q]怎么查看数据库参数</font><br />[A]show parameter 参数名<br />如通过show parameter spfile可以查看9i是否使用spfile文件<br />或者select * from v$parameter<br />除了这部分参数，Oracle还有大量隐含参数，可以通过如下语句查看:<br />SELECT NAME <br />,VALUE <br />,decode(isdefault, 'TRUE','Y','N') as "Default" <br />,decode(ISEM,'TRUE','Y','N') as SesMod <br />,decode(ISYM,'IMMEDIATE', 'I', <br />'DEFERRED', 'D', <br />'FALSE', 'N') as SysMod <br />,decode(IMOD,'MODIFIED','U', <br />'SYS_MODIFIED','S','N') as Modified <br />,decode(IADJ,'TRUE','Y','N') as Adjusted <br />,description <br />FROM ( --GV$SYSTEM_PARAMETER <br />SELECT x.inst_id as instance <br />,x.indx+1 <br />,ksppinm as NAME <br />,ksppity <br />,ksppstvl as VALUE <br />,ksppstdf as isdefault <br />,decode(bitand(ksppiflg/256,1),1,'TRUE','FALSE') as ISEM <br />,decode(bitand(ksppiflg/65536,3), <br />1,'IMMEDIATE',2,'DEFERRED','FALSE') as ISYM <br />,decode(bitand(ksppstvf,7),1,'MODIFIED','FALSE') as IMOD <br />,decode(bitand(ksppstvf,2),2,'TRUE','FALSE') as IADJ <br />,ksppdesc as DESCRIPTION <br />FROM x$ksppi x <br />,x$ksppsv y <br />WHERE x.indx = y.indx <br />AND substr(ksppinm,1,1) = '_' <br />AND x.inst_id = USERENV('Instance') <br />) <br />ORDER BY NAME<br /><font color="red">[Q]怎么样查看数据库字符集</font><br />[A]数据库服务器字符集select * from nls_database_parameters，其来源于props$，是表示数据库的字符集。<br />客户端字符集环境select * from nls_instance_parameters,其来源于v$parameter，<br />表示客户端的字符集的设置，可能是参数文件，环境变量或者是注册表<br />会话字符集环境 select * from nls_session_parameters，其来源于v$nls_parameters，表示会话自己的设置，可能是会话的环境变量或者是alter session完成，如果会话没有特殊的设置，将与nls_instance_parameters一致。<br />客户端的字符集要求与服务器一致，才能正确显示数据库的非Ascii字符。如果多个设置存在的时候，alter session&gt;环境变量&gt;注册表&gt;参数文件<br />字符集要求一致，但是语言设置却可以不同，语言设置建议用英文。如字符集是zhs16gbk，则nls_lang可以是American_America.zhs16gbk。<br /><font color="red">[Q]怎么样修改字符集</font><br />[A]8i以上版本可以通过alter database来修改字符集，但也只限于子集到超集，不建议修改props$表，将可能导致严重错误。<br />Startup nomount;<br />Alter database mount exclusive;<br />Alter system enable restricted session;<br />Alter system set job_queue_process=0;<br />Alter database open;<br />Alter database character set zhs16gbk;<br /><font color="red">[Q]怎样建立基于函数索引</font><br />[A]8i以上版本，确保<br />Query_rewrite_enabled=true<br />Query_rewrite_integrity=trusted<br />Compatible=8.1.0以上<br />Create index indexname on table (function(field));<br /><font color="red">[Q]怎么样移动表或表分区</font><br />[A]移动表的语法<br />Alter table tablename move<br />[Tablespace new_name<br />Storage(initial 50M next 50M <br />pctincrease 0 pctfree 10 pctused 50 initrans 2) nologging]<br />移动分区的语法<br />alter table tablename move (partition partname)<br />[update global indexes]<br />之后之后必须重建索引<br />Alter index indexname rebuild<br />如果表有Lob段，那么正常的Alter不能移动Lob段到别的表空间，而仅仅是移动了表段，可以采用如下的方法移动Lob段<br />alter table tablename move <br />lob(lobsegname) store as (tablespace newts);<br /><font color="red">[Q]怎么获得当前的SCN</font><br />[A]9i以下版本<br />select max(ktuxescnw*power(2,32)+ktuxescnb) from x$ktuxe;<br />如果是9i以上版本，还可以通过以下语句获取<br />select dbms_flashback.get_system_change_number from dual;<br /><font color="red">[Q]ROWID的结构与组成</font><br />[A]8以上版本的ROWID组成<br />OOOOOOFFFBBBBBBRRR<br />8以下ROWID组成（也叫受限Rowid）<br />BBBBBBBB.RRRR.FFFF<br />其中，O是对象ID，F是文件ID，B是块ID，R是行ID<br />如果我们查询一个表的ROWID，根据其中块的信息，可以知道该表确切占用了多少个块，进而知道占用了多少数据空间（此数据空间不等于表的分配空间）<br /><font color="red">[Q]怎么样获取对象的DDL语句</font><br />[A]第三方工具就不说了主要说一下9i以上版本的dbms_metadata<br />1、获得单个对象的DDL语句<br />set heading off<br />set echo off<br />set feedback off<br />set pages off<br />set long 90000<br />select dbms_metadata.get_ddl('TABLE','TABLENAME','SCAME') from dual;<br />如果获取整个用户的脚本，可以用如下语句<br />select dbms_metadata.get_ddl('TABLE',u.table_name) from user_tables u;<br />当然，如果是索引，则需要修改相关table到index<br /><font color="red">[Q]如何创建约束的索引在别的表空间上</font><br />[A]1、先创建索引，再创建约束<br />2、利用如下语句创建<br />create table test<br />(c1 number constraint pk_c1_id primary key<br />using index tablespace useridex,<br />c2 varchar2(10)<br />) tablespace userdate;<br /><font color="red">[Q]怎么知道那些表没有建立主键</font><br />[A]一般的情况下，表的主键是必要的，没有主键的表可以说是不符合设计规范的。<br />SELECT table_name<br />FROM User_tables t <br />WHERE NOT EXISTS <br />(SELECT table_name<br />FROM User_constraints c<br />WHERE constraint_type = 'P'<br />AND t.table_name=c.table_name)<br />其它相关数据字典解释<br />user_tables 表<br />user_tab_columns 表的列<br />user_constraints 约束<br />user_cons_columns 约束与列的关系<br />user_indexes 索