﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>语源科技BlogJava-yrJavaWorld</title><link>http://www.blogjava.net/yrJavaWorld/</link><description /><language>zh-cn</language><lastBuildDate>Sat, 18 Apr 2026 14:52:35 GMT</lastBuildDate><pubDate>Sat, 18 Apr 2026 14:52:35 GMT</pubDate><ttl>60</ttl><item><title>resolution to "Can't rollforward due to large bufferpool size "</title><link>http://www.blogjava.net/yrJavaWorld/archive/2007/03/15/104024.html</link><dc:creator>MyJavaWorld</dc:creator><author>MyJavaWorld</author><pubDate>Thu, 15 Mar 2007 07:21:00 GMT</pubDate><guid>http://www.blogjava.net/yrJavaWorld/archive/2007/03/15/104024.html</guid><wfw:comment>http://www.blogjava.net/yrJavaWorld/comments/104024.html</wfw:comment><comments>http://www.blogjava.net/yrJavaWorld/archive/2007/03/15/104024.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/yrJavaWorld/comments/commentRss/104024.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/yrJavaWorld/services/trackbacks/104024.html</trackback:ping><description><![CDATA[
		<p>Question:<br />The restore command works fine, but while attempting the rolforward of the sql logs, it complains about database falling short on bufferpool,and then terminates the rollforward process. One close look at the db2diag.log file, I noticed that db2 tried to start the database with the hidden bufferpool. But, apparently, that hidden bufferpool was pretty small to rollforward the logs and bring it online.<br /><br />I cannot reduce the bufferpool size as the database cannot be connected to.I cannot connect to the database as it is in rollforward pending state. I cannot rollforward the database, as it's not happy with the size of the *hidden* bufferpool and terminates.<br /><br />Answer:<br /><br /><font style="BACKGROUND-COLOR: #ffc0cb">db2set DB2_OVERRIDE_BPF=50000</font><br /><br />This will bring up all configured bufferpools using 50000 pages each. You<br />can choose a smaller/larger value that is suitable for your number of<br />bufferpools and available system memory. You can also configure each<br />bufferpool individually if you want<br /><br />値:<font style="BACKGROUND-COLOR: #7fffd4"> 正数のページ数 <br /></font>     OR<br /> <font style="BACKGROUND-COLOR: #ee82ee">&lt;entry&gt;[;&lt;entry&gt;...] (&lt;entry&gt;=&lt;バッファー・プール ID&gt;,&lt;ページ数&gt; )<br /><br />There is sitiuation that above solution does not work.<br /><br /></font></p>
		<pre>
				<font style="BACKGROUND-COLOR: #ffffff">When you try to create a bufferpool or alter a bufferpool to a
very large size and there is not enough memory in the system
, DB2 may occupies all pagespace and overrall performance of
the system become slow and may get hang at last because no
pagespace is available. Then after you connect the database
next time, DB2 will do crash recovery and still try to
allocate memory for this big bufferpool and occupy all
pagespace again. when you specify DB2_OVERRIDE_BPF parameter
to override bufferpool size, it doesn't take effect in this
situation. This is becasue DB2_OVERRIDE_BPF only applies for
bufferpools that already exist at startup, and not to
bufferpools that are created during crash recovery or roll
forward. We will fix this problem and check DB2_OVERRIDE_BPF
registry when creating bufferpools during crash recovery or
roll forward. This problem only occurs in a 64 bit instance.
</font>
		</pre>
		<p>
				<font style="BACKGROUND-COLOR: #ffffff">
						<b>Local fix</b>
				</font>
		</p>
		<pre>
				<font style="BACKGROUND-COLOR: #ffffff">You can use db2iupdt -w 32 &lt;INSTNAME&gt; to update the instance to
a 32 bit instance, then you can connect to the database
succefully. After that, use db2iupdt -w 64 &lt;INSTNAME&gt; to update
the instance to 64 bit again. Please take a backup at this
point, so we don't have to roll forward through bufferpool
creation that fails if we need restore and roll forward
database.
</font>
		</pre>
		<p>
				<font style="BACKGROUND-COLOR: #ffffff">
						<b>Problem summary</b>
				</font>
		</p>
		<pre>
				<font style="BACKGROUND-COLOR: #ffffff">Users Affected:
All users using 64 bit instance
Problem Description:
When you try to create a bufferpool or alter a bufferpool to a
very large size and there is not enough memory in the system
, DB2 may occupies all pagespace and overrall performance
of the system become slow and may get hang at last
because no pagespace is available. Then after you connect the
database at next time, DB2 will do crash recovery and still try
to allocate
memory for this big bufferpool and occupy all pagespace again.
In this situation, when you specify DB2_OVERRIDE_BPF parameter
to override bufferpool size, it doesn't take effect in this
situation. This
is becasue DB2_OVERRIDE_BPF only applies for bufferpools that
already exist at startup, and not to bufferpools that are
created during crash recovery or roll forward. We will fix
this problem and check
DB2_OVERRIDE_BPF registry when creating bufferpools during crash
recovery or roll forward. This problem only occurs in 64 bit
instance.
Problem Summary:
This problem is caused by a misoperation, when you create or alt
er a bufferpool, the size is too large to allocated from OS and
cause overrall performance of the system is very slow and seems
hang. Another problem is that DB2_OVERRIDE_BPF registry only app
lies to bufferpools that already exists, and not bufferpools wil
l be created in crash recovery or roll forward. So DB2 will try
to create this big bufferpool again when doing crash recovery or
 roll forward. We will fix this problem and check DB2_OVERRIDE_B
PF registry in our crash recovery and roll forward code.
</font>
		</pre>
		<p>
				<font style="BACKGROUND-COLOR: #ffffff">
						<b>Problem conclusion</b>
				</font>
		</p>
		<pre>
				<font style="BACKGROUND-COLOR: #ffffff">
				</font>
		</pre>
		<p>
				<font style="BACKGROUND-COLOR: #ffffff">
						<b>Temporary fix</b>
				</font>
		</p>
		<pre>
				<font style="BACKGROUND-COLOR: #ffffff">You can use db2iupdt -w 32 &lt;INSTNAME&gt; to update the instance to
a 32 bit instance, then you can connect to the database
succefully. After that, use db2iupdt -w 64 &lt;INSTNAME&gt; to update
the instance to 64 bit again. Please take a backup at this
point, so we don't have to roll forward through bufferpool
creation that fails if we need restore and roll
forward database.Please also notice that be careful when creati
ng bufferpool, don't specify a too large value.
</font>
		</pre>
		<p>
				<br />
				<font style="BACKGROUND-COLOR: #ffffff">
				</font>
		</p>
<img src ="http://www.blogjava.net/yrJavaWorld/aggbug/104024.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/yrJavaWorld/" target="_blank">MyJavaWorld</a> 2007-03-15 15:21 <a href="http://www.blogjava.net/yrJavaWorld/archive/2007/03/15/104024.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>about DB2 Administration (refer from others)</title><link>http://www.blogjava.net/yrJavaWorld/archive/2007/03/15/104021.html</link><dc:creator>MyJavaWorld</dc:creator><author>MyJavaWorld</author><pubDate>Thu, 15 Mar 2007 07:00:00 GMT</pubDate><guid>http://www.blogjava.net/yrJavaWorld/archive/2007/03/15/104021.html</guid><wfw:comment>http://www.blogjava.net/yrJavaWorld/comments/104021.html</wfw:comment><comments>http://www.blogjava.net/yrJavaWorld/archive/2007/03/15/104021.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/yrJavaWorld/comments/commentRss/104021.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/yrJavaWorld/services/trackbacks/104021.html</trackback:ping><description><![CDATA[
		<h3 class="entryheader" id="a000856">
				<a href="http://www.aiview.com/2006/12/change_db2_password_in_db2_level.html">Change db2 password in db2 level</a>
		</h3>
		<!--start #entryinfo~-->
		<div class="entryinfo" id="entryinfo000856">
				<p class="subtitle">December 28, 2006</p>
				<!--end #entryinfo~-->
		</div>
		<!--start #entrysummary~-->
		<div class="entrysummary" id="entrysummary000856" style="DISPLAY: none">DB2 depends on operation system level authorization to control DB2 system access.In some case, our db2... <!--end #entrysummary~--></div>
		<!--start #entrybody~-->
		<div class="entrybody" id="entrybody000856">
				<p>DB2 depends on operation system level authorization to control DB2 system access.</p>
				<p>In some case, our db2 account only allows to connect to instance or database, but not log on the system. In other words, we are not able to use the account to get a shell on unix or logon locally on windows. </p>
				<p>As usual, when we need to change db2 password, we take action on the system level because it's more frank. But in the case above that we can't get logon, we have to do it on db2 level. There are 2 ways.</p>
				<ul>
						<li>Use the GUI tool DB2 Configuration Assistance 
</li>
						<li>Use the command line tools DB2 CLP or CE</li>
				</ul>
				<h4>Using DB2 Configuration Assistance</h4>
				<p>Right click on a database name, then choose "Change password".</p>
				<p>
						<img height="302" alt="CA tool interface" src="http://www.aiview.com/ref/2006/12/db2ca_chgpasswd.jpg" width="342" border="0" />
				</p>
				<p>Note: When more than one databases live in same system, we might share the same account in multi-database. Changing password for one of them will affect all databases in this system. In other words, we don't need to do the change on each database, we could choose any we have privileges on the system.</p>
				<p>Limitation: We are not able to change our password in the case of that we are only allowed to attach to the node but not connect to any database, or we don't get the catalog information for any database in the node.</p>
				<p>For this limitation, it works out with the 2nd way. </p>
				<h4>Using DB2 CLP and CE</h4>
				<p>We could use CLP and CE to change password for databases and nodes that we connected or attached to.<br /></p>
				<ul>
						<li>Change by connecting to database</li>
				</ul>
				<pre class="cmd">C:\&gt; db2 connect to SAMPLE user TEST using OLDPWD new NEWPWD confirm NEWPWD<br />C:\&gt; db2 connect to SAMPLE user TEST using OLDPWD change password<br /></pre>
				<ul>
						<li>Change by attaching to node, this way works out for the limitation in Configuration Assistance</li>
				</ul>
				<pre class="cmd">C:\&gt; db2 attach to NODE user TEST using OLDPWD new NEWPWD confirm NEWPWD<br />C:\&gt; db2 attach to NODE user TEST using OLDPWD change password</pre>
				<br />
				<br />
				<!--end #entrybody~-->
		</div>
		<!--start #entryfooter~-->
		<div class="entryfooter" id="entryfooter000856">
				<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/DB2">DB2</a> (13), <a href="http://www.aiview.com/tag/Password">Password</a> (1) 相关的话题</p>
				<p class="posted">Posted by Alex at 2:16 PM | <a href="http://www.aiview.com/2006/12/change_db2_password_in_db2_level.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/12/change_db2_password_in_db2_level.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=856&amp;blog_id=1">Edit</a></p>
				<!--end #entryfooter~-->
		</div>
		<!--end #entry-->
		<!--start #entry~-->
		<div class="entry" id="entry000723">
				<a name="a000723">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000723">
								<label class="hidebodybar" id="hidebodybar000723">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000723">
								<a href="http://www.aiview.com/2006/04/alter_table_xxx_volatile.html">alter table xxx VOLATILE</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000723">
								<p class="subtitle">April 27, 2006</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000723" style="DISPLAY: none">valatilea. 反复无常的,挥发性的 VOLATILE CARDINALITY or NOT VOLATILE CARDINALITY Indicates to the optimizer whether or not the... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000723">
								<p>valatile</p>
								<ul>
										<li>a. 反复无常的,挥发性的 <br /></li>
								</ul>
								<blockquote>
										<p>VOLATILE CARDINALITY or NOT VOLATILE CARDINALITY <br />Indicates to the optimizer whether or not the cardinality of table table-name can<br />vary significantly at run time. Volatility applies to the number of rows in the <br />table, not to the table itself. CARDINALITY is an optional keyword. The default <br />is NOT VOLATILE. <br /><br />VOLATILE <br />Specifies that the cardinality of table table-name can vary significantly at <br />run time, from empty to large. To access the table, the optimizer will use <br />an index scan (rather than a table scan, regardless of the statistics) if that <br />index is index-only (all referenced columns are in the index), or that index <br />is able to apply a predicate in the index scan. The list prefetch access method <br />will not be used to access the table. If the table is a typed table, this option <br />is only supported on the root table of the typed table hierarchy (SQLSTATE 428DR). <br /><br />NOT VOLATILE <br />Specifies that the cardinality of table-name is not volatile. <br />Access plans to this table will continue to be based on existing statistics and <br />on the current optimization level.</p>
								</blockquote>
								<p>NOTE: The keyword could be specified within ALTER TABLE, but not CREATE TABLE. <br /></p>
								<p> </p>
								<!--end #entrybody~-->
						</div>
						<!--start #entryfooter~-->
						<div class="entryfooter" id="entryfooter000723">
								<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/DB2%20Administration">DB2 Administration</a> (12) 相关的话题</p>
								<p class="posted">Posted by Alex at 2:20 PM | <a href="http://www.aiview.com/2006/04/alter_table_xxx_volatile.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/04/alter_table_xxx_volatile.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=723&amp;blog_id=1">Edit</a></p>
								<!--end #entryfooter~-->
						</div>
						<!--end #entry-->
				</a>
		</div>
		<!--start #entry~-->
		<div class="entry" id="entry000679">
				<a name="a000679">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000679">
								<label class="hidebodybar" id="hidebodybar000679">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000679">
								<a href="http://www.aiview.com/2006/04/difference_between_local_and_system_database_directory.html">Difference between Local and System Database Directory</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000679">
								<p class="subtitle">April 13, 2006</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000679" style="DISPLAY: none">DB2 automatically catalogs databases when they are created. It catalogs an entryfor the database in the... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000679">
								<blockquote>
										<p>DB2 automatically catalogs databases when they are created. It catalogs an entry<br />for the database in the local database directory and another entry in the system <br />database directory. If the database is created from a remote client (or a client which <br />is executing from a different instance on the same machine), an entry is also made <br />in the system database directory at the client instance.<br /><br />Databases on the same node as the database manager instance are cataloged as <br /><strong>indirect </strong>entries. Databases on other nodes are cataloged as <strong>remote </strong>entries.</p>
								</blockquote>
								<p>List DBs in Local Database Directory</p>
								<pre class="cmd">$ db2 list db directory on /path_to_where_db_created </pre>
								<p>List DBs in System Database Directory</p>
								<pre class="cmd">$ db2 list db directory<br /></pre>
								<p> </p>
								<!--end #entrybody~-->
						</div>
						<!--start #entryfooter~-->
						<div class="entryfooter" id="entryfooter000679">
								<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/DB2%20Administration">DB2 Administration</a> (12) 相关的话题</p>
								<p class="posted">Posted by Alex at 2:55 PM | <a href="http://www.aiview.com/2006/04/difference_between_local_and_system_database_directory.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/04/difference_between_local_and_system_database_directory.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=679&amp;blog_id=1">Edit</a></p>
								<!--end #entryfooter~-->
						</div>
						<!--end #entry-->
				</a>
		</div>
		<!--start #entry~-->
		<div class="entry" id="entry000677">
				<a name="a000677">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000677">
								<label class="hidebodybar" id="hidebodybar000677">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000677">
								<a href="http://www.aiview.com/2006/04/illustration_of_standard_table.html">Illustration of standard tables</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000677">
								<p class="subtitle">April 12, 2006</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000677" style="DISPLAY: none">... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000677">
								<img height="826" alt="Standard Tables Overview" src="http://www.aiview.com/ref/2006/04/std_tab_overview.jpg" width="807" border="0" />
								<!--end #entrybody~-->
						</div>
						<!--start #entryfooter~-->
						<div class="entryfooter" id="entryfooter000677">
								<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/DB2%20Administration">DB2 Administration</a> (12) 相关的话题</p>
								<p class="posted">Posted by Alex at 6:26 PM | <a href="http://www.aiview.com/2006/04/illustration_of_standard_table.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/04/illustration_of_standard_table.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=677&amp;blog_id=1">Edit</a></p>
								<!--end #entryfooter~-->
						</div>
						<!--end #entry-->
				</a>
		</div>
		<!--start #entry~-->
		<div class="entry" id="entry000676">
				<a name="a000676">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000676">
								<label class="hidebodybar" id="hidebodybar000676">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000676">
								<a href="http://www.aiview.com/2006/04/query_the_status_for_one_specified_tablespace.html">Query the status for one specified tablespace?</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000676">
								<p class="subtitle">April 12, 2006</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000676" style="DISPLAY: none">As we know, we could issue following command to query status for all of tablespaces in... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000676">
								<p>As we know, we could issue following command to query status for all of tablespaces in current connected DB.</p>
								<pre class="cmd">$ db2 list tablespaces show detail &gt; /tmp/ts.list</pre>
								<p>Then find the status for the tablespaces we concerned.</p>
								<p>Is there's a way to query the status for one specified tablespace?</p>
								<p>My answer is No. </p>
								<ol>
										<li>First, I don't find the related column defination in the table or view: 
<ul><li>sysibm.systablespaces 
</li><li>syscat.tablespaces </li></ul></li>
										<li>Second, I don't think DB2 stores the status flag within syscata tables. The reason is that once a tablespace comes into a special status, it will not be allowed changing any longer(this may also happen on a system catalog tablespace.) that will lead to a conflict on changing the tablespace status flag if stores it within system catalog tables.</li>
								</ol>
								<!--end #entrybody~-->
						</div>
						<!--start #entryfooter~-->
						<div class="entryfooter" id="entryfooter000676">
								<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/DB2%20Administration">DB2 Administration</a> (12), <a href="http://www.aiview.com/tag/tablespace%20status">tablespace status</a> (1) 相关的话题</p>
								<p class="posted">Posted by Alex at 5:09 PM | <a href="http://www.aiview.com/2006/04/query_the_status_for_one_specified_tablespace.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/04/query_the_status_for_one_specified_tablespace.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=676&amp;blog_id=1">Edit</a></p>
								<!--end #entryfooter~-->
						</div>
						<!--end #entry-->
				</a>
		</div>
		<!--start #entry~-->
		<div class="entry" id="entry000675">
				<a name="a000675">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000675">
								<label class="hidebodybar" id="hidebodybar000675">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000675">
								<a href="http://www.aiview.com/2006/04/illustration_of_the_dms_table-space_address_map.html">Illustration of the DMS table-space address map</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000675">
								<p class="subtitle">April 11, 2006</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000675" style="DISPLAY: none">... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000675">
								<img height="481" alt="address map for DMS TS" src="http://www.aiview.com/ref/2006/04/dms_ts_addr_map.jpg" width="564" border="0" />
								<!--end #entrybody~-->
						</div>
						<!--start #entryfooter~-->
						<div class="entryfooter" id="entryfooter000675">
								<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/DB2%20Administration">DB2 Administration</a> (12) 相关的话题</p>
								<p class="posted">Posted by Alex at 4:46 PM | <a href="http://www.aiview.com/2006/04/illustration_of_the_dms_table-space_address_map.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/04/illustration_of_the_dms_table-space_address_map.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=675&amp;blog_id=1">Edit</a></p>
								<!--end #entryfooter~-->
						</div>
						<!--end #entry-->
				</a>
		</div>
		<!--start #entry~-->
		<div class="entry" id="entry000674">
				<a name="a000674">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000674">
								<label class="hidebodybar" id="hidebodybar000674">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000674">
								<a href="http://www.aiview.com/2006/04/db2_directories_and_files.html">DB2 directories and files</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000674">
								<p class="subtitle">April 11, 2006</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000674" style="DISPLAY: none">http://publib.boulder.ibm.com/infocenter/db2luw/v8//topic/com.ibm.db2.udb.doc/admin/c0005420.htm... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000674">
								<ul>
										<li>http://publib.boulder.ibm.com/infocenter/db2luw/v8//topic/com.ibm.db2.udb.doc/admin/c0005420.htm</li>
								</ul>
								<!--end #entrybody~-->
						</div>
						<!--start #entryfooter~-->
						<div class="entryfooter" id="entryfooter000674">
								<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/DB2%20Administration">DB2 Administration</a> (12) 相关的话题</p>
								<p class="posted">Posted by Alex at 3:51 PM | <a href="http://www.aiview.com/2006/04/db2_directories_and_files.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/04/db2_directories_and_files.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=674&amp;blog_id=1">Edit</a></p>
								<!--end #entryfooter~-->
						</div>
						<!--end #entry-->
				</a>
		</div>
		<!--start #entry~-->
		<div class="entry" id="entry000672">
				<a name="a000672">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000672">
								<label class="hidebodybar" id="hidebodybar000672">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000672">
								<a href="http://www.aiview.com/2006/04/illustration_of_db2_architechure_and_process.html">Illustration of DB2 architechure and process</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000672">
								<p class="subtitle">April 11, 2006</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000672" style="DISPLAY: none">Referencehttp://publib.boulder.ibm.com/infocenter/db2luw/v8//topic/com.ibm.db2.udb.doc/admin/c0005418.htm ... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000672">
								<p>
										<img height="649" alt="overview for tuning" src="http://www.aiview.com/ref/2006/04/arch_proc_overview.jpg" width="622" border="0" />
								</p>
								<p>Reference</p>
								<ul>
										<li>http://publib.boulder.ibm.com/infocenter/db2luw/v8//topic/com.ibm.db2.udb.doc/admin/c0005418.htm </li>
								</ul>
								<!--end #entrybody~-->
						</div>
						<!--start #entryfooter~-->
						<div class="entryfooter" id="entryfooter000672">
								<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/DB2%20Administration">DB2 Administration</a> (12) 相关的话题</p>
								<p class="posted">Posted by Alex at 2:21 PM | <a href="http://www.aiview.com/2006/04/illustration_of_db2_architechure_and_process.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/04/illustration_of_db2_architechure_and_process.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=672&amp;blog_id=1">Edit</a></p>
								<!--end #entryfooter~-->
						</div>
						<!--end #entry-->
				</a>
		</div>
		<!--start #entry~-->
		<div class="entry" id="entry000647">
				<a name="a000647">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000647">
								<label class="hidebodybar" id="hidebodybar000647">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000647">
								<a href="http://www.aiview.com/2006/03/tablespaces_are_put_into_backup_pending_after_a_load.html">Tablespaces are put into backup pending after a load</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000647">
								<p class="subtitle">March 29, 2006</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000647" style="DISPLAY: none">DB2 sets tablespace as Backup Pending state after loading data into a table in linear logging... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000647">DB2 sets tablespace as Backup Pending state after loading data into a table in linear logging database(that is, logretain or userexit is on), whatever the load is successful or failed. the reason is that the load process will not write log file. from the begin time of loading to the end time of loading, there will be a blank segment in log file, and the rollforward recovery can Not jump over the blank segment to apply the later log file.<br /><br /><p>so database needs a backup after loading to make sure db2 have recovery capicibility.</p><p>it's able to use <strike>[COPY YES|NO]  or</strike> [NONRECOVERABLE] to prevent tablespace go into Backup Pending state. <strike>COPY YES will do the backup automatically after loading, and COPY NO and</strike> NONRECOVERABLE will give up this backup that means db2 will be not able to recover the database once an serious error occured. <br /></p><br /><p>继续阅读 "<a href="http://www.aiview.com/2006/03/tablespaces_are_put_into_backup_pending_after_a_load.html#more">Tablespaces are put into backup pending after a load</a>" 的剩余内容</p><!--end #entrybody~--></div>
						<!--start #entryfooter~-->
						<div class="entryfooter" id="entryfooter000647">
								<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/DB2%20Administration">DB2 Administration</a> (12), <a href="http://www.aiview.com/tag/Load">Load</a> (1), <a href="http://www.aiview.com/tag/Tablespace">Tablespace</a> (1) 相关的话题</p>
								<p class="posted">Posted by Alex at 5:31 PM | <a href="http://www.aiview.com/2006/03/tablespaces_are_put_into_backup_pending_after_a_load.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/03/tablespaces_are_put_into_backup_pending_after_a_load.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=647&amp;blog_id=1">Edit</a></p>
								<!--end #entryfooter~-->
						</div>
						<!--end #entry-->
				</a>
		</div>
		<!--start #entry~-->
		<div class="entry" id="entry000511">
				<a name="a000511">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000511">
								<label class="hidebodybar" id="hidebodybar000511">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000511">
								<a href="http://www.aiview.com/2006/03/come_pending_when_droping_procedures.html">Come pending when droping Procedures</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000511">
								<p class="subtitle">March 21, 2006</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000511" style="DISPLAY: none">Problem Description There's no any response for creating or droping any procedures in DB2. Seems it's pending... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000511">
								<h4>Problem Description </h4>
								<p>There's no any response for creating or droping any procedures in DB2. Seems it's pending there, without any error returned. This time UPDATE statement on tables could be issued successfully.</p>
								<h4>Check Process</h4>
								<p>Check OS disk available</p>
								<pre class="cmd">$ df -kl </pre>
								<p>Check database configure</p>
								<pre class="cmd">db2 =&gt; get db cfg |more </pre>
								<p>Check system catalog tablespace </p>
								<pre class="cmd">db2 =&gt; list tablespaces show detail |more<br />syscatspace	0x0000 </pre>
								<h4>Cause </h4>
								<p>It caused by issuing CREATE or DROP statement without COMMIT or ROLLBACK statement in CLP which is in non-Autocommit mode.</p>
								<h4>Solution </h4>
								<p>After you issue a COMMIT or a ROLLBACK in the CLP or close it, the pending is gone.</p>
								<p>We must be very careful when we use client in non-Autocommit mode just like CLPs in this case.</p>
								<p>To check the Autocommit mode in CLP issues. Refer to: <br /></p>
								<p>
										<a href="http://www.aiview.com/2006/02/set_commit_mode_in_db2_clp.html">set COMMIT mode in db2 clp</a>
								</p>
								<pre class="cmd">db2 =&gt; list command options<br /><br /> -c    自动落实                                  OFF <br /></pre>
								<h4>More </h4>
								<p>From this point, we could get more. Most of strange things like this(pending there and no error return) are caused by locking. </p>
								<p>In this case, it was only the opertation on procedures being pended, so track on this thread to suppose the syscat tables related with procedures are locked then find the what probably causes it.<br /> <br /></p>
								<!--end #entrybody~-->
						</div>
						<!--start #entryfooter~-->
						<div class="entryfooter" id="entryfooter000511">
								<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/DB2%20Administration">DB2 Administration</a> (12), <a href="http://www.aiview.com/tag/DB2%20Development">DB2 Development</a> (24), <a href="http://www.aiview.com/tag/Procedure">Procedure</a> (3) 相关的话题</p>
								<p class="posted">Posted by Alex at 6:13 PM | <a href="http://www.aiview.com/2006/03/come_pending_when_droping_procedures.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/03/come_pending_when_droping_procedures.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=511&amp;blog_id=1">Edit</a></p>
								<!--end #entryfooter~-->
						</div>
						<!--end #entry-->
				</a>
		</div>
		<!--start #entry~-->
		<div class="entry" id="entry000366">
				<a name="a000366">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000366">
								<label class="hidebodybar" id="hidebodybar000366">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000366">
								<a href="http://www.aiview.com/2006/03/db2_can_not_create_index_on_local_view.html">db2 can not create index on local view</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000366">
								<p class="subtitle">March 7, 2006</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000366" style="DISPLAY: none">There's an object called index view since MS SQL Server 2000, it's an index which is... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000366">
								<p>There's an object called index view since MS SQL Server 2000, it's an index which is created on an view which is based on a local table. it is attent to imporve the select performence on the view when this view is based on multi-table and has complex logic.</p>
								<p>I try to find a simular thing in DB2, but there's no the simular solution in DB2 v8.2 for now. Instead, I found another thing instested.</p>
								<p>DB2 allows creating index on the tables or views in remote data source, such as a database on another host or an XML data source. To be exactly, that's Not true Index, it's Index Specification. It requests that the tables in remote data source have created index in its own system. And it only repeat the index description in local system.</p>
								<pre class="output" style="WIDTH: 90%; HEIGHT: 46px">
										<strong>Local DB2 Env                                            Remote DB2 Env</strong>
										<br />
										<br />Index Specification    -&gt;    Nickname    - - -&gt;   True Index    -&gt;    Table</pre>
								<p>See following example in DB2 info center. </p>
								<ul>
										<li>
												<a title="Reference" onclick="parent.parent.parent.setContentToolbarTitle(this.title)" href="http://publib.boulder.ibm.com/infocenter/db2luw/v8//topic/com.ibm.db2.udb.doc/admin/r0000919.htm?resultof=%22%63%72%65%61%74%65%22%20%22%63%72%65%61%74%22%20%22%69%6e%64%65%78%22%20%22%73%74%61%74%65%6d%65%6e%74%22%20">CREATE INDEX statement<br /></a>
												<span class="active">http://publib.boulder.ibm.com/infocenter/db2luw/v8//topic/com.ibm.db2.udb.doc/admin/r0000919.htm?resultof=%22%63%72%65%61%74%65%22%20%22%63%72%65%61%74%22%20%22%69%6e%64%65%78%22%20%22%73%74%61%74%65%6d%65%6e%74%22%20</span>
												<a title="Reference" onclick="parent.parent.parent.setContentToolbarTitle(this.title)" href="http://publib.boulder.ibm.com/infocenter/db2luw/v8//topic/com.ibm.db2.udb.doc/admin/r0000919.htm?resultof=%22%63%72%65%61%74%65%22%20%22%63%72%65%61%74%22%20%22%69%6e%64%65%78%22%20%22%73%74%61%74%65%6d%65%6e%74%22%20">
														<br />
												</a>
										</li>
								</ul>
								<p>Example 3:  The nickname EMPLOYEE references a data source table called CURRENT_EMP. After this nickname was created, an index was defined on CURRENT_EMP. The columns chosen for the index key were WORKDEBT and JOB. Create an index specificationindex. Through this specification, the optimizer will know that the index exists and what its key is. With this information, the optimizer can improve its strategy to access the table. that describes this </p>
								<pre class="code" style="WIDTH: 90%; HEIGHT: 89px">   CREATE UNIQUE INDEX JOB_BY_DEPT<br />     ON EMPLOYEE (WORKDEPT, JOB)<br />     SPECIFICATION ONLY        </pre>
								<p>Note: the Nickname is only allowed to be created on tables in local database and on much kind of objects at remote data source. It's not allowed to be created on views in local database. <br /></p>
								<!--end #entrybody~-->
						</div>
						<!--start #entryfooter~-->
						<div class="entryfooter" id="entryfooter000366">
								<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/DB2%20Administration">DB2 Administration</a> (12), <a href="http://www.aiview.com/tag/index">index</a> (1) 相关的话题</p>
								<p class="posted">Posted by Alex at 5:43 PM | <a href="http://www.aiview.com/2006/03/db2_can_not_create_index_on_local_view.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/03/db2_can_not_create_index_on_local_view.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=366&amp;blog_id=1">Edit</a></p>
								<!--end #entryfooter~-->
						</div>
						<!--end #entry-->
				</a>
		</div>
		<!--start #entry~-->
		<div class="entry" id="entry000063">
				<a name="a000063">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000063">
								<label class="hidebodybar" id="hidebodybar000063">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000063">
								<a href="http://www.aiview.com/2006/02/set_commit_mode_in_db2_clp.html">set COMMIT mode in db2 clp</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000063">
								<p class="subtitle">February 28, 2006</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000063" style="DISPLAY: none">As default, DB2 CLP will do commit after you issue each DB2 statements or SQL automatically.If... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000063">
								<p>As default, DB2 CLP will do commit after you issue each DB2 statements or SQL automatically.</p>
								<p>If you want to change it instead of issuing COMMIT or ROLLBACK manually, do following.</p>
								<pre class="output" style="WIDTH: 90%; HEIGHT: 138px">SQLLIB\BIN&gt; db2<br />db2 =&gt; list command options<br />    -c   ON<br />db2 =&gt; update command options using c off<br />db2 =&gt; list command options<br />    -c    OFF</pre>
								<p>This change will only exists during this session. The setting will lose when you close this CLP and open CLP next time.</p>
								<p>following cmd will get the same result with above.</p>
								<pre class="output" style="WIDTH: 90%; HEIGHT: 207px">SQLLIB\BIN&gt; db2 list command options<br />    -c    ON<br />SQLLIB\BIN&gt; db2 +c<br />db2 =&gt;<br />db2 =&gt; list command options<br />    -c    OFF<br />db2 =&gt; quit<br />SQLLIB\BIN&gt; db2 list command options<br />    -c    ON<br /></pre>
								<p>There's also the way to keep the settings forever, do following.</p>
								<pre class="output" style="WIDTH: 90%; HEIGHT: 115px">SQLLIB\BIN\&gt; db2 list command options<br />    -c    ON<br />SQLLIB\BIN\&gt; db2set db2options=+c<br />SQLLIB\BIN\&gt; db2 list command options<br />    -c    OFF</pre>
								<p>This change will take effection immediately even for others having been opened CLP windows. And will keep along.</p>
								<p>Use following cmd set it back to ON. </p>
								<pre class="cmd">SQLLIB\BIN&gt; db2set db2opptions=-c</pre>
								<h4>Reference</h4>
								<ul>
										<li>
												<a href="http://www.chinaunix.net/jh/22/164405.html">http://www.chinaunix.net/jh/22/164405.html </a>
										</li>
								</ul>
								<!--end #entrybody~-->
						</div>
						<!--start #entryfooter~-->
						<div class="entryfooter" id="entryfooter000063">
								<p>标签 Tags: 其它与<a href="http://www.aiview.com/tag/commit">commit</a> (1), <a href="http://www.aiview.com/tag/DB2%20Administration">DB2 Administration</a> (12) 相关的话题</p>
								<p class="posted">Posted by Alex at 8:28 PM | <a href="http://www.aiview.com/2006/02/set_commit_mode_in_db2_clp.html#comments">Comments (0)</a> | <a href="http://www.aiview.com/2006/02/set_commit_mode_in_db2_clp.html#trackbacks">TrackBack (0)</a> | <a title="edit this entry, only for admin" href="http://www.aiview.com/cgi-bin/mt/mt.cgi?__mode=view&amp;_type=entry&amp;id=63&amp;blog_id=1">Edit</a></p>
								<!--end #entryfooter~-->
						</div>
						<!--end #entry-->
				</a>
		</div>
		<!--start #entry~-->
		<div class="entry" id="entry000587">
				<a name="a000587">
						<!--start #top-entry~-->
						<div class="top-entry" id="top-entry000587">
								<label class="hidebodybar" id="hidebodybar000587">
								</label>
								<!--end #top-entry~-->
						</div>
						<h3 class="entryheader" id="a000587">
								<a href="http://www.aiview.com/2005/08/rename_tables_and_indexs.html">表与索引的重命名 RENAME</a>
						</h3>
						<!--start #entryinfo~-->
						<div class="entryinfo" id="entryinfo000587">
								<p class="subtitle">August 18, 2005</p>
								<!--end #entryinfo~-->
						</div>
						<!--start #entrysummary~-->
						<div class="entrysummary" id="entrysummary000587" style="DISPLAY: none">在DB2 中重命名表或者索引db2=&gt; RENAME TABLE EMP TO EMPLOYEEdb2=&gt; RENAME TABLE ABC.EMP TO EMPLOYEE db2=&gt; RENAME INDEX NEW-IND... <!--end #entrysummary~--></div>
						<!--start #entrybody~-->
						<div class="entrybody" id="entrybody000587">
								<p>在DB2 中重命名表或者索引</p>
								<pre class="cmd">db2=&gt; RENAME TABLE EMP TO EMPLOYEE<br />db2=&gt; RENAME TABLE ABC.EMP TO EMPLOYEE <br />db2=&gt; RENAME INDEX NEW-IND TO IND<br />db2=&gt; RENAME INDEX ABC.NEW-IND TO IND</pre>
						</div>
				</a>
		</div>
<img src ="http://www.blogjava.net/yrJavaWorld/aggbug/104021.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/yrJavaWorld/" target="_blank">MyJavaWorld</a> 2007-03-15 15:00 <a href="http://www.blogjava.net/yrJavaWorld/archive/2007/03/15/104021.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>三个UNIX文件时间ctime、mtime、atime</title><link>http://www.blogjava.net/yrJavaWorld/archive/2007/03/13/103602.html</link><dc:creator>MyJavaWorld</dc:creator><author>MyJavaWorld</author><pubDate>Tue, 13 Mar 2007 09:51:00 GMT</pubDate><guid>http://www.blogjava.net/yrJavaWorld/archive/2007/03/13/103602.html</guid><wfw:comment>http://www.blogjava.net/yrJavaWorld/comments/103602.html</wfw:comment><comments>http://www.blogjava.net/yrJavaWorld/archive/2007/03/13/103602.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/yrJavaWorld/comments/commentRss/103602.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/yrJavaWorld/services/trackbacks/103602.html</trackback:ping><description><![CDATA[三个UNIX文件时间ctime、mtime、atime<br />       我曾经根据文件的状态在指定时间内是否改变写过一个WatchDog来对服务进行监控，其间曾被这三个时间搞混淆，所以觉得很有必要和大家分享我对这三个术语的理解。<br />      ctime（change time）改变时间：是指文件状态最后一次被改变的时间；<br />      mtime（modification time）修改时间：是指文件内容最后一次被改变的时间；<br />      atime（access time）访问时间：是指文件最后一次被读取的时间。<br />      前两者的区别就在于文件状态的改变既包括文件索引节点的改变，也包括文件内容的改变。也就是说如果你改变了文件内容，则同时更新了ctime和mtime，但是如果你只改变了文件索引节点则只是改变了ctime。atime只有在文件被读取的时侯才会改变。它的改变与文件状态以及文件内容的改变没有直接的联系。<br />     例如：echo “Hello World” &gt;&gt; myfile 则同时改变了ctime和mtime，atime不变；<br />     chmod u+x myfile 则只改变了ctime,mtime和atime不变。<br />     cat myfile，则只改变了atime，ctime和mtime不变<br />     ps:以上操作均在redhat linux下验证通过<img src ="http://www.blogjava.net/yrJavaWorld/aggbug/103602.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/yrJavaWorld/" target="_blank">MyJavaWorld</a> 2007-03-13 17:51 <a href="http://www.blogjava.net/yrJavaWorld/archive/2007/03/13/103602.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>DB2/SQL命令大全</title><link>http://www.blogjava.net/yrJavaWorld/archive/2006/12/28/90530.html</link><dc:creator>MyJavaWorld</dc:creator><author>MyJavaWorld</author><pubDate>Thu, 28 Dec 2006 08:57:00 GMT</pubDate><guid>http://www.blogjava.net/yrJavaWorld/archive/2006/12/28/90530.html</guid><wfw:comment>http://www.blogjava.net/yrJavaWorld/comments/90530.html</wfw:comment><comments>http://www.blogjava.net/yrJavaWorld/archive/2006/12/28/90530.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/yrJavaWorld/comments/commentRss/90530.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/yrJavaWorld/services/trackbacks/90530.html</trackback:ping><description><![CDATA[
		<center>
				<div id="usrbar">
						<nobr>
						</nobr> </div>
				<div id="main" style="WIDTH: 996px" align="left">
						<script><![CDATA[
var objmain = document.getElementById("main");
function updatesize(){ var bodyw = window.document.body.offsetWidth; if(bodyw <= 790) objmain.style.width="772px"; else if(bodyw >= 1016) objmain.style.width="996px"; else objmain.style.width="100%"; }
updatesize(); window.onresize = updatesize;
]]&gt;</script>
						<div id="header">
								<div class="rc"> </div>
						</div>
						<div class="stage">
								<div class="stagepad">
										<div style="WIDTH: 100%">
												<table class="modth" cellspacing="0" cellpadding="0" width="100%" border="0">
														<tbody>
																<tr>
																		<td class="modtl" width="7"> </td>
																		<td class="modtc" nowrap="">
																				<div class="modhead">
																						<span class="modtit">查看文章</span>
																				</div>
																		</td>
																		<td class="modtc" nowrap="" align="right">
																		</td>
																		<td class="modtr" width="7"> </td>
																</tr>
														</tbody>
												</table>
												<div class="modbox" id="m_blog">
														<div class="tit">DB2/SQL命令大全</div>
														<div class="date">2006-12-25 13:21</div>
														<table style="TABLE-LAYOUT: fixed">
																<tbody>
																		<tr>
																				<td>
																						<div class="cnt">
																								<p>连接数据库：</p>
																								<p>  connect to [数据库名] user [操作用户名] using [密码] </p>
																								<p>创建缓冲池(8K)：</p>
																								<p>  create bufferpool ibmdefault8k IMMEDIATE  SIZE 5000 PAGESIZE 8 K ;<br />创建缓冲池(16K)(OA_DIVERTASKRECORD)：<br />  create bufferpool ibmdefault16k IMMEDIATE  SIZE 5000 PAGESIZE 16 K ;<br />创建缓冲池(32K)(OA_TASK)：<br />  create bufferpool ibmdefault32k IMMEDIATE  SIZE 5000 PAGESIZE 32 K ;</p>
																								<p>创建表空间：</p>
																								<p>  CREATE TABLESPACE exoatbs IN DATABASE PARTITION GROUP IBMDEFAULTGROUP PAGESIZE 8K MANAGED BY SYSTEM USING ('/home/exoa2/exoacontainer') EXTENTSIZE 32 PREFETCHSIZE 16  BUFFERPOOL IBMDEFAULT8K  OVERHEAD 24.10 TRANSFERRATE 0.90  DROPPED TABLE RECOVERY OFF;</p>
																								<p>  CREATE TABLESPACE exoatbs16k  IN DATABASE PARTITION GROUP IBMDEFAULTGROUP PAGESIZE 16K MANAGED BY SYSTEM USING ('/home/exoa2/exoacontainer16k'   ) EXTENTSIZE 32  PREFETCHSIZE 16  BUFFERPOOL IBMDEFAULT16K  OVERHEAD 24.1 TRANSFERRATE 0.90  DROPPED TABLE RECOVERY OFF;</p>
																								<p>  CREATE TABLESPACE exoatbs32k  IN DATABASE PARTITION GROUP IBMDEFAULTGROUP PAGESIZE 32K MANAGED BY SYSTEM USING ('/home/exoa2/exoacontainer32k'   ) EXTENTSIZE 32  PREFETCHSIZE 16  BUFFERPOOL IBMDEFAULT32K  OVERHEAD 24.1 TRANSFERRATE 0.90  DROPPED TABLE RECOVERY OFF;</p>
																								<p>GRANT USE OF TABLESPACE exoatbs TO PUBLIC;<br />GRANT USE OF TABLESPACE exoatbs16k TO PUBLIC;<br />GRANT USE OF TABLESPACE exoatbs32k TO PUBLIC;</p>
																								<p>创建系统表空间：</p>
																								<p>  CREATE TEMPORARY TABLESPACE exoasystmp IN DATABASE PARTITION GROUP IBMTEMPGROUP PAGESIZE 8K  MANAGED BY SYSTEM USING ('/home/exoa2/exoasystmp'   ) EXTENTSIZE 32 PREFETCHSIZE 16 BUFFERPOOL IBMDEFAULT8K  OVERHEAD 24.10 TRANSFERRATE 0.90  DROPPED TABLE RECOVERY OFF;</p>
																								<p>  CREATE TEMPORARY TABLESPACE exoasystmp16k IN DATABASE PARTITION GROUP IBMTEMPGROUP PAGESIZE 16K MANAGED BY SYSTEM USING ('/home/exoa2/exoasystmp16k'  ) EXTENTSIZE 32 PREFETCHSIZE 16 BUFFERPOOL IBMDEFAULT16K OVERHEAD 24.10 TRANSFERRATE 0.90  DROPPED TABLE RECOVERY OFF;</p>
																								<p>  CREATE TEMPORARY TABLESPACE exoasystmp32k IN DATABASE PARTITION GROUP IBMTEMPGROUP PAGESIZE 32K MANAGED BY SYSTEM USING ('/home/exoa2/exoasystmp32k') EXTENTSIZE 32 PREFETCHSIZE 16 BUFFERPOOL IBMDEFAULT32K OVERHEAD 24.10 TRANSFERRATE 0.90  DROPPED TABLE RECOVERY OFF;</p>
																								<p>1. 启动实例(db2inst1):</p>
																								<p>db2start</p>
																								<p>2. 停止实例(db2inst1):</p>
																								<p>db2stop</p>
																								<p>3. 列出所有实例(db2inst1)</p>
																								<p>db2ilist</p>
																								<p>5.列出当前实例:</p>
																								<p>db2 get instance</p>
																								<p>4. 察看示例配置文件:</p>
																								<p>db2 get dbm cfg|more</p>
																								<p>5. 更新数据库管理器参数信息:</p>
																								<p>db2 update dbm cfg using para_name para_value</p>
																								<p>6. 创建数据库:</p>
																								<p>db2 create db test</p>
																								<p>7. 察看数据库配置参数信息</p>
																								<p>db2 get db cfg for test|more</p>
																								<p>8. 更新数据库参数配置信息</p>
																								<p>db2 update db cfg for test using para_name para_value</p>
																								<p>10.删除数据库:</p>
																								<p>db2 drop db test</p>
																								<p>11.连接数据库</p>
																								<p>db2 connect to test</p>
																								<p>12.列出所有表空间的详细信息。</p>
																								<p>db2 list tablespaces show detail</p>
																								<p>13.查询数据:</p>
																								<p>db2 select * from tb1</p>
																								<p>14.删除数据:</p>
																								<p>db2 delete from tb1 where id=1</p>
																								<p>15.创建索引:</p>
																								<p>db2 create index idx1 on tb1(id);</p>
																								<p>16.创建视图:</p>
																								<p>db2 create view view1 as select id from tb1</p>
																								<p>17.查询视图:</p>
																								<p>db2 select * from view1</p>
																								<p>18.节点编目</p>
																								<p>db2 catalog tcp node node_name remote server_ip server server_port</p>
																								<p>19.察看端口号</p>
																								<p>db2 get dbm cfg|grep SVCENAME</p>
																								<p>20.测试节点的附接</p>
																								<p>db2 attach to node_name</p>
																								<p>21.察看本地节点</p>
																								<p>db2 list node direcotry</p>
																								<p>22.节点反编目</p>
																								<p>db2 uncatalog node node_name</p>
																								<p>23.数据库编目</p>
																								<p>db2 catalog db db_name as db_alias at node node_name</p>
																								<p>24.察看数据库的编目</p>
																								<p>db2 list db directory</p>
																								<p>25.连接数据库</p>
																								<p>db2 connect to db_alias user user_name using user_password</p>
																								<p>26.数据库反编目</p>
																								<p>db2 uncatalog db db_alias</p>
																								<p>27.导出数据</p>
																								<p>db2 export to myfile of ixf messages msg select * from tb1</p>
																								<p>28.导入数据</p>
																								<p>db2 import from myfile of ixf messages msg replace into tb1</p>
																								<p>29.导出数据库的所有表数据</p>
																								<p>db2move test export</p>
																								<p>30.生成数据库的定义</p>
																								<p>db2look -d db_alias -a -e -m -l -x -f -o db2look.sql</p>
																								<p>31.创建数据库</p>
																								<p>db2 create db test1</p>
																								<p>32.生成定义</p>
																								<p>db2 -tvf db2look.sql</p>
																								<p>33.导入数据库所有的数据</p>
																								<p>db2move db_alias import</p>
																								<p>34.重组检查</p>
																								<p>db2 reorgchk</p>
																								<p>35.重组表tb1</p>
																								<p>db2 reorg table tb1</p>
																								<p>36.更新统计信息</p>
																								<p>db2 runstats on table tb1</p>
																								<p>37.备份数据库test</p>
																								<p>db2 backup db test</p>
																								<p>38.恢复数据库test</p>
																								<p>db2 restore db test</p>
																								<p>399\.列出容器的信息</p>
																								<p>db2 list tablespace containers for tbs_id show detail</p>
																								<p>40.创建表:</p>
																								<p>db2 ceate table tb1(id integer not null,name char(10))</p>
																								<p>41.列出所有表</p>
																								<p>db2 list tables</p>
																								<p>42.插入数据:</p>
																								<p>db2 insert into tb1 values(1,’sam’);</p>
																								<p>db2 insert into tb2 values(2,’smitty’);</p>
																								<p>. 建立数据库DB2_GCB </p>
																								<p>CREATE DATABASE DB2_GCB ON G: ALIAS DB2_GCB </p>
																								<p>USING CODESET GBK TERRITORY CN COLLATE USING SYSTEM DFT_EXTENT_SZ 32 </p>
																								<p>2. 连接数据库 </p>
																								<p>connect to sample1 user db2admin using 8301206 </p>
																								<p>3. 建立别名 </p>
																								<p>create alias db2admin.tables for sysstat.tables; </p>
																								<p>CREATE ALIAS DB2ADMIN.VIEWS FOR SYSCAT.VIEWS </p>
																								<p>create alias db2admin.columns for syscat.columns; </p>
																								<p>create alias guest.columns for syscat.columns; </p>
																								<p>4. 建立表 </p>
																								<p>create table zjt_tables as </p>
																								<p>(select * from tables) definition only; </p>
																								<p>create table zjt_views as </p>
																								<p>(select * from views) definition only; </p>
																								<p>5. 插入记录 </p>
																								<p>insert into zjt_tables select * from tables; </p>
																								<p>insert into zjt_views select * from views; </p>
																								<p>6. 建立视图 </p>
																								<p>create view V_zjt_tables as select tabschema,tabname from zjt_tables; </p>
																								<p>7. 建立触发器 </p>
																								<p>CREATE TRIGGER zjt_tables_del </p>
																								<p>AFTER DELETE ON zjt_tables </p>
																								<p>REFERENCING OLD AS O </p>
																								<p>FOR EACH ROW MODE DB2SQL </p>
																								<p>Insert into zjt_tables1 values(substr(o.tabschema,1,8),substr(o.tabname,1,10)) </p>
																								<p>8. 建立唯一性索引 </p>
																								<p>CREATE UNIQUE INDEX I_ztables_tabname </p>
																								<p>[size=3]ON zjt_tables(tabname); </p>
																								<p>9. 查看表 </p>
																								<p>select tabname from tables </p>
																								<p>where tabname='ZJT_TABLES'; </p>
																								<p>10. 查看列 </p>
																								<p>select SUBSTR(COLNAME,1,20) as 列名,TYPENAME as 类型,LENGTH as 长度 </p>
																								<p>from columns </p>
																								<p>where tabname='ZJT_TABLES'; </p>
																								<p>11. 查看表结构 </p>
																								<p>db2 describe table user1.department </p>
																								<p>db2 describe select * from user.tables </p>
																								<p>12. 查看表的索引 </p>
																								<p>db2 describe indexes for table user1.department </p>
																								<p>13. 查看视图 </p>
																								<p>select viewname from views </p>
																								<p>where viewname='V_ZJT_TABLES'; </p>
																								<p>14. 查看索引 </p>
																								<p>select indname from indexes </p>
																								<p>where indname='I_ZTABLES_TABNAME'; </p>
																								<p>15. 查看存贮过程 </p>
																								<p>SELECT SUBSTR(PROCSCHEMA,1,15),SUBSTR(PROCNAME,1,15) </p>
																								<p>FROM SYSCAT.PROCEDURES; </p>
																								<p>16. 类型转换(cast) </p>
																								<p>ip datatype:varchar </p>
																								<p>select cast(ip as integer)+50 from log_comm_failed </p>
																								<p>17. 重新连接 </p>
																								<p>connect reset </p>
																								<p>18. 中断数据库连接 </p>
																								<p>disconnect db2_gcb </p>
																								<p>19. view application </p>
																								<p>LIST APPLICATION; </p>
																								<p>20. kill application </p>
																								<p>FORCE APPLICATION(0); </p>
																								<p>db2 force applications all (强迫所有应用程序从数据库断开) </p>
																								<p>21. lock table</p>
																								<p>lock table test in exclusive mode </p>
																								<p>22. 共享 </p>
																								<p>lock table test in share mode </p>
																								<p>23. 显示当前用户所有表 </p>
																								<p>list tables </p>
																								<p>24. 列出所有的系统表 </p>
																								<p>list tables for system </p>
																								<p>25. 显示当前活动数据库 </p>
																								<p>list active databases </p>
																								<p>26. 查看命令选项 </p>
																								<p>list command options </p>
																								<p>27. 系统数据库目录 </p>
																								<p>LIST DATABASE DIRECTORY </p>
																								<p>28. 表空间 </p>
																								<p>list tablespaces </p>
																								<p>29. 表空间容器 </p>
																								<p>LIST TABLESPACE CONTAINERS FOR </p>
																								<p>Example: LIST TABLESPACE CONTAINERS FOR 1 </p>
																								<p>30. 显示用户数据库的存取权限 </p>
																								<p>GET AUTHORIZATIONS </p>
																								<p>31. 启动实例 </p>
																								<p>DB2START </p>
																								<p>32. 停止实例 </p>
																								<p>db2stop </p>
																								<p>33. 表或视图特权 </p>
																								<p>grant select,delete,insert,update on tables to user </p>
																								<p>grant all on tables to user WITH GRANT OPTION </p>
																								<p>34. 程序包特权 </p>
																								<p>GRANT EXECUTE </p>
																								<p>ON PACKAGE PACKAGE-name </p>
																								<p>TO PUBLIC </p>
																								<p>35. 模式特权 </p>
																								<p>GRANT CREATEIN ON SCHEMA SCHEMA-name TO USER </p>
																								<p>36. 数据库特权 </p>
																								<p>grant connect,createtab,dbadm on database to user </p>
																								<p>37. 索引特权 </p>
																								<p>grant control on index index-name to user </p>
																								<p>38. 信息帮助 (? XXXnnnnn ) </p>
																								<p>例:? SQL30081 </p>
																								<p>39. SQL 帮助(说明 SQL 语句的语法) </p>
																								<p>help statement </p>
																								<p>例如，help SELECT </p>
																								<p>40. SQLSTATE 帮助(说明 SQL 的状态和类别代码) </p>
																								<p>? sqlstate 或 ? class-code </p>
																								<p>41. 更改与"管理服务器"相关的口令 </p>
																								<p>db2admin setid username password </p>
																								<p>42. 创建 SAMPLE 数据库 </p>
																								<p>db2sampl </p>
																								<p>db2sampl F:(指定安装盘) </p>
																								<p>43. 使用操作系统命令 </p>
																								<p>! dir </p>
																								<p>44. 转换数据类型 (cast) </p>
																								<p>SELECT EMPNO, CAST(RESUME AS VARCHAR(370)) </p>
																								<p>FROM EMP_RESUME </p>
																								<p>WHERE RESUME_FORMAT = 'ascii' </p>
																								<p>45. UDF</p>
																								<p>要运行 DB2 Java 存储过程或 UDF，还需要更新服务器上的 DB2 数据库管理程序配置，以包括在该机器上安装 JDK 的路径 </p>
																								<p>db2 update dbm cfg using JDK11_PATH d:sqllibjavajdk </p>
																								<p>TERMINATE </p>
																								<p>update dbm cfg using SPM_NAME sample </p>
																								<p>46. 检查 DB2 数据库管理程序配置 </p>
																								<p>db2 get dbm cfg </p>
																								<p>47. 检索具有特权的所有授权名 </p>
																								<p>SELECT DISTINCT GRANTEE, GRANTEETYPE, 'DATABASE' FROM SYSCAT.DBAUTH </p>
																								<p>UNION </p>
																								<p>SELECT DISTINCT GRANTEE, GRANTEETYPE, 'TABLE ' FROM SYSCAT.TABAUTH </p>
																								<p>UNION </p>
																								<p>SELECT DISTINCT GRANTEE, GRANTEETYPE, 'PACKAGE ' FROM SYSCAT.PACKAGEAUTH </p>
																								<p>UNION </p>
																								<p>SELECT DISTINCT GRANTEE, GRANTEETYPE, 'INDEX ' FROM SYSCAT.INDEXAUTH </p>
																								<p>UNION </p>
																								<p>SELECT DISTINCT GRANTEE, GRANTEETYPE, 'COLUMN ' FROM SYSCAT.COLAUTH </p>
																								<p>UNION </p>
																								<p>SELECT DISTINCT GRANTEE, GRANTEETYPE, 'SCHEMA ' FROM SYSCAT.SCHEMAAUTH </p>
																								<p>UNION </p>
																								<p>SELECT DISTINCT GRANTEE, GRANTEETYPE, 'SERVER ' FROM SYSCAT.PASSTHRUAUTH </p>
																								<p>ORDER BY GRANTEE, GRANTEETYPE, 3 </p>
																								<p>create table yhdab </p>
																								<p>(id varchar(10), </p>
																								<p>password varchar(10), </p>
																								<p>ywlx varchar(10), </p>
																								<p>kh varchar(10)); </p>
																								<p>create table ywlbb </p>
																								<p>(ywlbbh varchar(8), </p>
																								<p>ywmc varchar(60)) </p>
																								<p>48. 修改表结构 </p>
																								<p>alter table yhdab ALTER kh SET DATA TYPE varchar(13); </p>
																								<p>alter table yhdab ALTER ID SET DATA TYPE varchar(13); </p>
																								<p>alter table lst_bsi alter bsi_money set data type int; </p>
																								<p>insert into yhdab values </p>
																								<p>('20000300001','123456','user01','20000300001'), </p>
																								<p>('20000300002','123456','user02','20000300002'); </p>
																								<p>49. 业务类型说明 </p>
																								<p>insert into ywlbb values </p>
																								<p>('user01','业务申请'), </p>
																								<p>('user02','业务撤消'), </p>
																								<p>('user03','费用查询'), </p>
																								<p>('user04','费用自缴'), </p>
																								<p>('user05','费用预存'), </p>
																								<p>('user06','密码修改'), </p>
																								<p>('user07','发票打印'), </p>
																								<p>('gl01','改用户基本信息'), </p>
																								<p>('gl02','更改支付信息'), </p>
																								<p>('gl03','日统计功能'), </p>
																								<p>('gl04','冲帐功能'), </p>
																								<p>('gl05','对帐功能'), </p>
																								<p>('gl06','计费功能'), </p>
																								<p>('gl07','综合统计') </p>
																								<p>备份数据库：<br />CONNECT TO EXOA;<br />QUIESCE DATABASE IMMEDIATE FORCE CONNECTIONS;<br />CONNECT RESET;<br />BACKUP DATABASE EXOA TO "/home/exoa2/db2bak/" WITH 2 BUFFERS BUFFER 1024 PARALLELISM 1 WITHOUT PROMPTING;<br />CONNECT TO EXOA;<br />UNQUIESCE DATABASE;<br />CONNECT RESET;</p>
																								<p>以下是小弟在使用db2move中的一些经验，希望对大家有所帮助。 </p>
																								<p> db2   connect   to  YOURDB   <br />连接数据库 </p>
																								<p> db2look -d  YOURDB  -a -e -x -o creatab.sql <br />导出建库表的SQL </p>
																								<p> db2move   YOURDB  export <br />用db2move将数据备份出来 </p>
																								<p> vi   creatab.sql <br />如要导入的数据库名与原数据库不同，要修改creatab.sql中CONNECT 项 <br />如相同则不用更改 </p>
																								<p> db2move  NEWDB  load <br />将数据导入新库中 </p>
																								<p>在导入中可能因为种种原因发生中断，会使数据库暂挂 <br />db2    list tablespaces   show   detail <br />如： <br />      详细说明： <br />     装入暂挂 <br /> 总页数                          = 1652 <br /> 可用页数                        = 1652 <br /> 已用页数                         = 1652 <br /> 空闲页数                         = 不适用 <br /> 高水位标记（页）                 = 不适用 <br /> 页大小（字节）                   = 4096 <br /> 盘区大小（页）                   = 32 <br /> 预读取大小（页）                 = 32 <br /> 容器数                           = 1 <br /> 状态更改表空间标识                    = 2 <br /> 状态更改对象标识                      = 59 </p>
																								<p> db2 select tabname,tableid from syscat.tables where tableid=59 <br />查看是哪张表挂起 </p>
																								<p>表名知道后到db2move.lst(在db2move  YOURDB  export的目录中)中找到相应的.ixf文件 <br /> db2 load from tab11.ixf of ixf terminate into db2admin.xxxxxxxxx <br />tab11.ixf对应的是xxxxxxxxx表 </p>
																								<p>数据库会恢复正常，可再用db2 list tablespaces show detail查看<br /><br /></p>
																								<p>30.不能通过GRANT授权的权限有哪种? </p>
																								<p>SYSAM </p>
																								<p>SYSCTRL </p>
																								<p>SYSMAINT </p>
																								<p>要更该述权限必须修改数据库管理器配置参数 </p>
																								<p>31.表的类型有哪些? </p>
																								<p>永久表(基表) </p>
																								<p>临时表(说明表) </p>
																								<p>临时表(派生表) </p>
																								<p>32.如何知道一个用户有多少表? </p>
																								<p>SELECT*FROMSYSIBM.SYSTABLESWHERECREATOR='USER' </p>
																								<p>33.如何知道用户下的函数? </p>
																								<p>select*fromIWH.USERFUNCTION </p>
																								<p>select*fromsysibm.SYSFUNCTIONS </p>
																								<p>34.如何知道用户下的VIEW数? </p>
																								<p>select*fromsysibm.sysviewsWHERECREATOR='USER' </p>
																								<p>35.如何知道当前DB2的版本? </p>
																								<p>select*fromsysibm.sysvERSIONS </p>
																								<p>36.如何知道用户下的TRIGGER数? </p>
																								<p>select*fromsysibm.SYSTRIGGERSWHERESCHEMA='USER' </p>
																								<p>37.如何知道TABLESPACE的状况? </p>
																								<p>select*fromsysibm.SYSTABLESPACES </p>
																								<p>38.如何知道SEQUENCE的状况? </p>
																								<p>select*fromsysibm.SYSSEQUENCES </p>
																								<p>39.如何知道SCHEMA的状况? </p>
																								<p>select*fromsysibm.SYSSCHEMATA </p>
																								<p>40.如何知道INDEX的状况? </p>
																								<p>select*fromsysibm.SYSINDEXES </p>
																								<p>41.如何知道表的字段的状况? </p>
																								<p>select*fromsysibm.SYSCOLUMNSWHERETBNAME='AAAA' </p>
																								<p>42.如何知道DB2的数据类型? </p>
																								<p>select*fromsysibm.SYSDATATYPES </p>
																								<p>43.如何知道BUFFERPOOLS状况? </p>
																								<p>select*fromsysibm.SYSBUFFERPOOLS </p>
																								<p>44.DB2表的字段的修改限制? </p>
																								<p>只能修改VARCHAR2类型的并且只能增加不能减少. </p>
																								<p>45.如何查看表的结构? </p>
																								<p>DESCRIBLETABLETABLE_NAME </p>
																								<p>OR </p>
																								<p>DESCRIBLESELECT*FROMSCHEMA.TABLE_NAME </p>
																						</div>
																				</td>
																		</tr>
																</tbody>
														</table>
														<div class="opt"> </div>
														<div id="in_send">
																<form name="form1" onsubmit="return checkcmtform()" action="/jianxijun/commit" method="post"> </form>
														</div>
														<br />
												</div>
												<table height="8" cellspacing="0" cellpadding="0" width="100%" border="0">
														<tbody>
																<tr>
																		<td class="modbl" width="7"> </td>
																		<td class="modbc"> </td>
																		<td class="modbr" width="7"> </td>
																</tr>
														</tbody>
												</table>
										</div>
								</div>
						</div>
				</div>
				<center>
						<div id="ft"> </div>
				</center>
		</center>
<img src ="http://www.blogjava.net/yrJavaWorld/aggbug/90530.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/yrJavaWorld/" target="_blank">MyJavaWorld</a> 2006-12-28 16:57 <a href="http://www.blogjava.net/yrJavaWorld/archive/2006/12/28/90530.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>DB2 UDB中用户出口程序是如何工作的</title><link>http://www.blogjava.net/yrJavaWorld/archive/2006/12/08/86425.html</link><dc:creator>MyJavaWorld</dc:creator><author>MyJavaWorld</author><pubDate>Fri, 08 Dec 2006 10:12:00 GMT</pubDate><guid>http://www.blogjava.net/yrJavaWorld/archive/2006/12/08/86425.html</guid><wfw:comment>http://www.blogjava.net/yrJavaWorld/comments/86425.html</wfw:comment><comments>http://www.blogjava.net/yrJavaWorld/archive/2006/12/08/86425.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/yrJavaWorld/comments/commentRss/86425.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/yrJavaWorld/services/trackbacks/86425.html</trackback:ping><description><![CDATA[
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together; mso-outline-level: 1">
				<b>DB2 UDB中用户出口程序是如何工作的？</b>
		</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">
				<b>
				</b> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">采用用户出口程序与DB2 UDB共同工作背后的基本思想是提供一种归档和检索数据库日志文件的方法以实现日志冗余处理并从易失性介质上转储出来。重要的，值得注意的是，根据你的特殊需求，在用户出口程序当中，除了能实现归档和检索日志之外，你还可以实现其他的操作。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">如果一个数据库需要采用归档日志文件来进行恢复，在DB2 UDB中实行用户出口程序策略将不能恢复100%的事务。用户出口程序只是一种通过拷贝已经存在的日志文件到一个安全的地方来为其提供更多保护的方法。它是数据完整性策略中的一部分，而且是重要的一部分。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">编译了用户出口程序之后，可执行程序db2uext2被放置在数据库管理器可以找到的目录当中。在UNIX<font face="Times New Roman">©</font>中，这个目录是<instance home="" />/sqllib/adm；在Windows<font face="Times New Roman">©</font>中，是<drive letter="" />Program FilesIBMSQLLIBBIN。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">除非数据库管理器知道用户出口程序是可用的，不然它不会调用db2uext2。让数据库管理器知道db2uext2可以被调用的唯一方法是将数据库配置参数userexit设置为on。一旦这个参数被设定好而且DB2实例被重复利用了，数据库管理器将每五分钟调用一次用户出口程序来检查那些可以被归档到程序相关的归档目录的日志文件。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">如果数据库的恢复是必要的，在前滚操作期间，数据库管理器将调用db2uext2把归档日志文件拷贝回活动的日志目录当中。然后，日志文件被再次运用到重建的数据库中。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">让我们看看被数据库管理器生成的到用户出口程序的调用的格式。注意，这一信息也可以在用户出口示例程序的注释部分找到。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">db2uext2 -OS<os /> -RL<release /></p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">-RQ<request /> -DB<dbname /> -NN<nodenumber /></p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">-LP<logpath /> -LN<logname /> [-AP]</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">其中：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">os=操作系统</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">release=DB2发行版本</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">request= 'ARCHIVE' 或 'RETRIEVE'</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">dbname=数据库名</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">nodenumber=节点号</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">logpath=日志文件目录</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">logname=日志文件名</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">logsize=日志文件大小（可选）</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">startingpage=以4k页为单位的起始偏移量（可选）</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">adsmpasswd=ADSM密码（可选）</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
				<b>注意</b>：只有当logpath为裸设备时才使用logsize和startingpage。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">归档或者从磁盘检索日志文件遵从以下命名规则：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">归档：归档路径＋数据库名＋节点号＋日志文件名</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">检索：检索路径＋数据库名＋节点号＋日志文件名</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">比如：如果归档的路径为”c:mylogs”,</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">检索路径是“c:mylogs”，</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">数据库名是“SAMPLE”，</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">节点号是 NODE0000，</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">文件名是 S0000001.LOG，</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">日志文件将是：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">归档到 - c:mylogsSAMPLENODE0000S0000001.LOG</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">检索自 - c:mylogsSAMPLENODE0000S0000001.LOG</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">以下描述了用户出口程序中的逻辑是如何运转的：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">1)  安装信号处理程序。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">2)  验证传递的参数个数。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">3)  验证操作请求。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">4)  开始审计跟踪（如果有此请求）。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">5)  根据操作需求的不同获取以下路径中的一个：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; mso-outline-level: 1" align="left">a)  如果操作需求为归档一个文件，将日志文件从日志路径拷贝到归档路径中。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">i） 如果没有找到日志文件，执行第6点。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; mso-outline-level: 1" align="left">b)  如果操作需求是检索一个文件，将日志文件从检索路径拷贝到日志路径中。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">i） 如果没有找到日志文件，执行第6点。<br /><br />6) 将错误记入日志（如果要求或者有需要的话）。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">7)  结束审计跟踪（如果有请求）。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">8)  以适当的返回码退出。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">手工调用用户出口程序来归档日志文件是可以的，但最好还是使用ARCHIVE LOG命令以便在定义以上参数时不会因为你的原因导致错误。在这篇文章的末尾，可以找到关于ARCHIVE LOG命令的链接。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together">
				<b>日志文件术语</b>
		</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">
				<b>
				</b> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">DB2 中用户出口程序的基本功能是将日志文件拷贝到活动日志目录或反之。这里，值得指出一些术语来阐明活动的日志目录被置于何处以及数据库日志文件的状态如何。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together">
				<b>活动日志目录：</b>
		</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">
				<b>
				</b> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">该目录被置于你的数据库目录中。在Windows中，如果在C:中创建了一个叫做SAMPLE的单一数据库且实例名为db2inst1，则将会出现以下的目录结构：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; mso-outline-level: 1; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">C:DB2INST1NODE0000SQL000001SQLOGDIR</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-outline-level: 1">SQL00001是SAMPLE数据库的数据库目录，SQLOGDIR 是活动日志目录。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">以下的图1显示了Windows操作系统上的活动日志目录：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: center; mso-layout-grid-align: none" align="center">
				<shapetype id="_x0000_t75" coordsize="21600,21600" o:spt="75" o:preferrelative="t" path="m@4@5l@4@11@9@11@9@5xe" filled="f" stroked="f" />
				<stroke joinstyle="miter" />
				<formulas />
				<f eqn="if lineDrawn pixelLineWidth 0" />
				<f eqn="sum @0 1 0" />
				<f eqn="sum 0 0 @1" />
				<f eqn="prod @2 1 2" />
				<f eqn="prod @3 21600 pixelWidth" />
				<f eqn="prod @3 21600 pixelHeight" />
				<f eqn="sum @0 0 1" />
				<f eqn="prod @6 1 2" />
				<f eqn="prod @7 21600 pixelWidth" />
				<f eqn="sum @8 21600 0" />
				<f eqn="prod @7 21600 pixelHeight" />
				<f eqn="sum @10 21600 0" />PATH o:extrusionok="f" gradientshapeok="t" o:connecttype="rect" /&gt;<lock v:ext="edit" aspectratio="t" />SHAPE id=_x0000_i1025 style="WIDTH: 299.25pt; HEIGHT: 180.75pt" type="#_x0000_t75" /&gt;<imagedata src="file:///C:/DOCUME~1/ADMINI~1/LOCALS~1/Temp/msoclip1/01/clip_image001.png" o:title="" />/P&gt;
</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: center; mso-layout-grid-align: none" align="center"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: center; mso-layout-grid-align: none" align="center">图 1活动日志目录</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together">
				<b>日志文件状态</b>
		</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
				<b>
				</b> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">在活动日志目录中，日志文件可以是活动日志，也可以是联机归档日志。活动日志是那些被 DB2 用于当前事务处理和崩溃恢复的日志。联机归档日志是那些 DB2 UDB 进行常规处理时不再需要，而进行数据库恢复时可能还会需要的日志。当实现用户出口程序时，这些联机归档日志将最终以归档日志目录中的副本形式出现。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">既然<font face="Times New Roman"> DB2 UDB </font>中用户出口程序的目的是将数据库日志拷贝到归档目录中，你将最终在活动日志目录（缺省为<font face="Times New Roman"> SQLOGDIR</font>）中得到重复的日志文件。你可能考虑删除这些重复的联机归档日志以释放文件系统空间。在从数据库目录中除去这些日志之前，要十分小心地确认它们是否已经将成功地被复制到归档目录中。还必须确保数据库管理器进行崩溃恢复时不再需要它们。要确定你的活动日志目录中哪些日志文件不为正常处理所需要，可用通过以下命令检查数据库配置：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">         </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 24.75pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">     db2 "get db cfg for sample"</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">这条命令的数据库配置输出结果将包含第一个活动日志文件，如：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">First active log file = S000009.LOG</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">在如上所示的输出当中，日志文件S000009.LOG是数据库当前的活动日志。任何编号比该日志文件小的日志文件都被看作联机归档日志。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">这里有一个例子：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">在这个场景中，活动日志目录中有日志文件 S000000.LOG - S000009.LOG，归档日志目录中有 S000000.LOG - S000008.LOG。因为 S000009.LOG 是第一个活动日志文件，所以，可以从活动日志目录中移走 S000001.LOG - S000008.LOG 以释放磁盘空间。S000009.LOG 文件必须保留在活动日志目录中，因为它仍然被当前事务使用。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">同样可以通过检查数据库历史文件来查看活动日志目录中哪些日志文件不再有用。以下命令将列出数据库备份信息：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 24.75pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">     db2 "list history backup all for database sample"</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">以下是该命令的输出结果的一个例子：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; mso-outline-level: 1; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">List History File for sample<br /><br /></p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">Number of matching file entries = 4</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">Op Obj Timestamp+Sequence Type Dev Earliest Log Current  Log </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">-- --- ------------------ ---- --- ------------------------ </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; mso-outline-level: 1; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">B D 20030416162026001 F D S0000010.LOGS0000014.LOG</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">------------------------------------------------------------</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">Contains 2 tablespace(s):</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; mso-outline-level: 1; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">00001 SYSCATSPACE </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; mso-outline-level: 1; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">00002 USERSPACE1</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">------------------------------------------------------------</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">在上面的输出中，最早的日志将表示，需要 S0000010.LOG 及其之后的任何日志。 S00000010.LOG 之前的任何日志可以被安全的删除。再次提醒，在从活动日志目录中删除日志文件之前，验证在活动日志目录中存在这些日志文件的拷贝是十分重要的。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">虽然可以手动的从活动日志目录中删除日志文件，删除联机归档日志文件的安全方法是通过prune logfile命令。该命令可以用来删除活动归档目录中的日志文件。在下面的示例中，以下命令将删除日志文件 S000000.LOG - S000008.LOG：</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 24.75pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">     db2 "prune logfile prior to S000009.LOG"</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">
				<b>注意：</b>根据您的恢复策略，可能会出现之前的前滚操作在数据库上执行的场景。归档目录中的老日志文件可能被同名的新日志文件所覆盖，从而阻止你使用旧日志文件对数据库进行时间点恢复。对用户出口程序的设计程序员来说，考虑类似这样的情况是很重要的。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together">
				<b>设置用户出口</b>
		</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">
				<b>
				</b> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">在本文中，我们将采用DB2提供的db2uext2.cdisk样例c程序，它位于你的c目录当中。在UNIX中，c目录位于<instance_home />/sqllib/samples。Windows中，这目录位于Program Files/IBM/<instance_name />/samples。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together">
				<b>在Windows中设置用户出口</b>
		</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together">
				<b>
				</b> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together">
				<b>修改和编译用户出口程序</b>
		</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">1.  创建名为C:mylogs的目录</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">2.  将C:Program filesIBMSQLLIBsamplescdb2uext2.cdisk拷贝到一个工作目录当中</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">3.  对于本示例，用户出口程序的以下部分应该得以验证以反映路径 c:\mylogs\</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">#define ARCHIVE_PATH "c:\mylogs\" </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">#define RETRIEVE_PATH "c:\mylogs\" </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">#define AUDIT_ACTIVE 1 /* enable audit trail logging */ </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">#define ERROR_ACTIVE 1 /* enable error trail logging */ </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">#define AUDIT_ERROR_PATH "c:\mylogs\" </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">                 /* path must end with a slash */ </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">#define AUDIT_ERROR_ATTR "a" /* append to text file */ </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none; tab-stops: 45.8pt 91.6pt 137.4pt 183.2pt 229.0pt 274.8pt 320.6pt 366.4pt 412.2pt 458.0pt 503.8pt 549.6pt 595.4pt 641.2pt 687.0pt 732.8pt" align="left">#define BUFFER_SIZE 32 </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">    /* # of 4K pages for output buffer */</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">4.  确定在你的系统中安装了被支持的C编译器（比如，Microsoft Visual Studio）而且环境中有该编译器的路径。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">5.  通过命令行，将db2uext2.cdisk更名为db2uext2.c并构建：<br /><br />cl db2uext2.c</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt 21pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none">一旦程序被编译，将创建db2uext2.exe和db2uext2.obj文件。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">6.  将可执行文件db2uext2.exe放到/SQLLIB/BIN目录当中从而使数据库管理器能够定位并执行它用以归档和检索日志。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together"> </p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; mso-layout-grid-align: none; mso-pagination: lines-together">
				<b>为用户出口创建并准备数据库</b>
		</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">7.  在 DB2 命令窗口中用 db2sampl 命令创建 SAMPLE 数据库。这将使你对下面的示例使用样本表。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">db2sampl</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">8.  更新数据库配置文件以便为数据库打开用户出口。请注意：只能为一个数据库分配用户出口程序，因为 bin 目录被所有 DB2 实例共享。</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">db2 "update db cfg for sample using userexit on"</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">db2stop force</p>
		<p>
		</p>
		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 21pt; LINE-HEIGHT: 12pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">&lt;span lang="EN-US" style="FONT-SIZE: 10pt; COLOR: black; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-bidi-font-family: 宋体; mso- </p>/P&gt;<img src ="http://www.blogjava.net/yrJavaWorld/aggbug/86425.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/yrJavaWorld/" target="_blank">MyJavaWorld</a> 2006-12-08 18:12 <a href="http://www.blogjava.net/yrJavaWorld/archive/2006/12/08/86425.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>如何使用keytool创建密钥仓库 (转)</title><link>http://www.blogjava.net/yrJavaWorld/archive/2006/10/31/78328.html</link><dc:creator>MyJavaWorld</dc:creator><author>MyJavaWorld</author><pubDate>Tue, 31 Oct 2006 09:18:00 GMT</pubDate><guid>http://www.blogjava.net/yrJavaWorld/archive/2006/10/31/78328.html</guid><wfw:comment>http://www.blogjava.net/yrJavaWorld/comments/78328.html</wfw:comment><comments>http://www.blogjava.net/yrJavaWorld/archive/2006/10/31/78328.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/yrJavaWorld/comments/commentRss/78328.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/yrJavaWorld/services/trackbacks/78328.html</trackback:ping><description><![CDATA[
		<table id="HB_Mail_Container" height="100%" cellspacing="0" cellpadding="0" width="100%" border="0" unselectable="on">
				<tbody>
						<tr height="100%" width="100%" unselectable="on">
								<td id="HB_Focus_Element" valign="top" width="100%" background="" height="250" unselectable="off">
										<font face="Simsun">其实主要的就是要创建一个密钥仓库以管理您的公钥</font>
										<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">/</span>
										<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">私钥对来自您所信任实体的证书。<br /></span>
										<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥"> <br /></span>
										<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">
												<strong>第一步：</strong>生成密钥对</span>
										<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">
												<br />
										</span>
										<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">您首先要做的是创建一个密钥仓库和生成密钥对。您可以使用以下命令：</span>
										<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥"> <br />keytool -genkey -keyalg RSA -keysize 512 -dname "cn=hyq,o=eagle,c=cn" -alias weblogic -keypass 123456 -keystore C:/mykeystore/weblogic.jks -storepass 123456 -validity 365<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /?><o:p></o:p></span>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">（请注意：键入该命令时必须使其成为一行。此处用多行来显示，主要是为了可读性。）如下图：<br /><img height="152" alt="Snap2.gif" src="http://www.blogjava.net/images/blogjava_net/trampeagle/Snap2.gif" width="648" border="0" /><br /><img height="1" src="/WebResource.axd?d=pLXXeGbWF7eXU8SMs2-GFZvUWY2JNH05dFx5YzJhGUYAYJAFEaTEq36NAhTPy7_KekvzDFwt8wvQWdByvJIGWdEq6x2KpKD80&amp;t=632780334080781250" width="1" /></span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">
														<br />
												</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">该命令将在</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥"> C </span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">盘的</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">“mykeystore”</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">目录中创建名为</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">“weblogic.jks”</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">的密钥仓库，并赋予它口令</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">“</span>
												<?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" /?>
												<st1:chmetcnv w:st="on" tcsc="0" numbertype="1" negative="False" hasspace="False" sourcevalue="123456" unitname="”">
														<span lang="EN-US" style="FONT-SIZE: 12pt; mso-font-kerning: 0pt">123456</span>
														<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">”</span>
												</st1:chmetcnv>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">。它将为实体生成公钥</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">/</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">私钥对，该实体的</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">“</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">特征名</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">”</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">为：常用名</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">“hyq”</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">、组织</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">“eagle”</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">和两个字母的国家代码</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">“cn”</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">。“</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; mso-font-kerning: 0pt">-keyalg</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">”指定它使用的是那种密钥生成算法来创建密钥，缺省的是</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">“DSA”</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">密钥生成算法（会使用缺省的</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">“</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">带</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥"> DSA </span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">的</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥"> SHA<st1:chmetcnv w:st="on" tcsc="0" numbertype="1" negative="False" hasspace="False" sourcevalue="1" unitname="”">1”</st1:chmetcnv></span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">签名算法），两个密钥（公钥与私钥）的长度是</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">512</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">位，由</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; mso-font-kerning: 0pt">-keysize</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt">来指定，默认的是</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">1024 </span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">位。</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥"> </span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">该证书包括公钥和特征名信息。该证书的有效期为</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">365</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">天，由</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">-validity</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">来指定，且与别名</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">“business”</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">所代表的密钥仓库项关联。私钥被赋予口令</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">“</span>
												<st1:chmetcnv w:st="on" tcsc="0" numbertype="1" negative="False" hasspace="False" sourcevalue="123456" unitname="”">
														<span lang="EN-US" style="FONT-SIZE: 12pt; mso-font-kerning: 0pt">123456</span>
														<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">”</span>
												</st1:chmetcnv>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">。</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">
														<o:p>
														</o:p>
												</span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">
														<o:p> </o:p>
												</span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-INDENT: 126.5pt; TEXT-ALIGN: left; mso-char-indent-count: 12.0; mso-layout-grid-align: none" align="left">
												<b style="mso-bidi-font-weight: normal">
														<span style="FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt; mso-bidi-font-family: 宋体">命令行里</span>
												</b>
												<b style="mso-bidi-font-weight: normal">
														<span lang="EN-US" style="FONT-FAMILY: Tahoma; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt">DName </span>
												</b>
												<b style="mso-bidi-font-weight: normal">
														<span style="FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt; mso-bidi-font-family: 宋体">信息注解</span>
												</b>
												<b style="mso-bidi-font-weight: normal">
														<span lang="EN-US" style="FONT-SIZE: 10pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">
																<o:p>
																</o:p>
														</span>
												</b>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">
														<o:p> </o:p>
												</span>
										</p>
										<table class="MsoTableGrid" style="BORDER-RIGHT: medium none; BORDER-TOP: medium none; BORDER-LEFT: medium none; BORDER-BOTTOM: medium none; BORDER-COLLAPSE: collapse; mso-border-alt: solid windowtext .5pt; mso-yfti-tbllook: 480; mso-padding-alt: 0cm 5.4pt 0cm 5.4pt; mso-border-insideh: .5pt solid windowtext; mso-border-insidev: .5pt solid windowtext" cellspacing="0" cellpadding="0" border="1">
												<tbody>
														<tr style="mso-yfti-irow: 0; mso-yfti-firstrow: yes">
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: windowtext 1pt solid; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: windowtext 1pt solid; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
																				<span lang="EN-US" style="FONT-FAMILY: Tahoma; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt">DN </span>
																				<span style="FONT-FAMILY: 宋体; mso-hansi-font-family: Tahoma; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt; mso-bidi-font-family: 宋体">信息域</span>
																				<span lang="EN-US" style="FONT-SIZE: 10pt; FONT-FAMILY: Tahoma; mso-font-kerning: 0pt">
																						<o:p>
																						</o:p>
																				</span>
																		</p>
																</td>
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: windowtext 1pt solid; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: #ece9d8; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-left-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
																				<span style="FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt; mso-bidi-font-family: 宋体">含义</span>
																				<span lang="EN-US" style="FONT-SIZE: 10pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">
																						<o:p>
																						</o:p>
																				</span>
																		</p>
																</td>
														</tr>
														<tr style="mso-yfti-irow: 1">
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: windowtext 1pt solid; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
																				<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">CN<o:p></o:p></span>
																		</p>
																</td>
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: #ece9d8; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-left-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
																				<span style="FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt; mso-bidi-font-family: 宋体">域名或</span>
																				<span lang="EN-US" style="FONT-FAMILY: Tahoma; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt">IP</span>
																				<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">
																						<o:p>
																						</o:p>
																				</span>
																		</p>
																</td>
														</tr>
														<tr style="mso-yfti-irow: 2">
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: windowtext 1pt solid; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
																				<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">OU<o:p></o:p></span>
																		</p>
																</td>
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: #ece9d8; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-left-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
																				<span style="FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt; mso-bidi-font-family: 宋体">部门，没有部门的可不要此项</span>
																				<span lang="EN-US" style="FONT-SIZE: 10pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">
																						<o:p>
																						</o:p>
																				</span>
																		</p>
																</td>
														</tr>
														<tr style="mso-yfti-irow: 3">
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: windowtext 1pt solid; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
																				<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">O<o:p></o:p></span>
																		</p>
																</td>
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: #ece9d8; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-left-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
																				<span style="FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt; mso-bidi-font-family: 宋体">单位名称</span>
																				<span lang="EN-US" style="FONT-SIZE: 10pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">
																						<o:p>
																						</o:p>
																				</span>
																		</p>
																</td>
														</tr>
														<tr style="mso-yfti-irow: 4">
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: windowtext 1pt solid; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
																				<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">L<o:p></o:p></span>
																		</p>
																</td>
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: #ece9d8; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-left-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
																				<span style="FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt; mso-bidi-font-family: 宋体">单位地址</span>
																				<span lang="EN-US" style="FONT-SIZE: 10pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">
																						<o:p>
																						</o:p>
																				</span>
																		</p>
																</td>
														</tr>
														<tr style="mso-yfti-irow: 5">
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: windowtext 1pt solid; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
																				<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">S<o:p></o:p></span>
																		</p>
																</td>
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: #ece9d8; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-left-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
																				<span style="FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt; mso-bidi-font-family: 宋体">省份的拼音（第一个字母大写）</span>
																				<span lang="EN-US" style="FONT-SIZE: 10pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">
																						<o:p>
																						</o:p>
																				</span>
																		</p>
																</td>
														</tr>
														<tr style="mso-yfti-irow: 6; mso-yfti-lastrow: yes">
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: windowtext 1pt solid; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
																				<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">C<o:p></o:p></span>
																		</p>
																</td>
																<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 5.4pt; BORDER-TOP: #ece9d8; PADDING-LEFT: 5.4pt; PADDING-BOTTOM: 0cm; BORDER-LEFT: #ece9d8; WIDTH: 213.05pt; PADDING-TOP: 0cm; BORDER-BOTTOM: windowtext 1pt solid; BACKGROUND-COLOR: transparent; mso-border-alt: solid windowtext .5pt; mso-border-left-alt: solid windowtext .5pt; mso-border-top-alt: solid windowtext .5pt" valign="top" width="284">
																		<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
																				<span style="FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt; mso-bidi-font-family: 宋体">国家的简写 （</span>
																				<span lang="EN-US" style="FONT-FAMILY: Tahoma; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt">CN </span>
																				<span style="FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-size: 10.5pt; mso-bidi-font-family: 宋体">代表中国）</span>
																				<span lang="EN-US" style="FONT-SIZE: 10pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">
																						<o:p>
																						</o:p>
																				</span>
																		</p>
																</td>
														</tr>
												</tbody>
										</table>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">
														<br />
												</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">如果采用选项的缺省值，可以大大缩短该命令。实际上，这些选项并不是必需的；对于有缺省值的选项，未指定时将使用缺省值，对于任何被要求的值，您将会得到要求输入它的提示。例如：输入命令</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">keytool -genkey -keystore "C:/tone.jks" -storepass 123456 -keyalg RSA</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">，就会有如下提示：<br /><img height="339" alt="Snap3.gif" src="http://www.blogjava.net/images/blogjava_net/trampeagle/Snap3.gif" width="645" border="0" /><br /></span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">
														<o:p>
														</o:p>
												</span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt">
														<o:p>
														</o:p>
												</span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times New Roman'; mso-hansi-font-family: 'Times New Roman'">
														<img height="1" src="/WebResource.axd?d=pLXXeGbWF7eXU8SMs2-GFZvUWY2JNH05dFx5YzJhGUYAYJAFEaTEq36NAhTPy7_KekvzDFwt8wvQWdByvJIGWdEq6x2KpKD80&amp;t=632780334080781250" width="1" />
														<br />注意：这里的</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">密钥仓库路径一定要存在，如果不存在的话，它就会抛如下的异常<br /></span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">
														<o:p>
														</o:p>
												</span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">
														<o:p>
														</o:p>
												</span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
												<b style="mso-bidi-font-weight: normal">
														<span style="FONT-SIZE: 14pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">
																<img height="39" alt="Snap4.gif" src="http://www.blogjava.net/images/blogjava_net/trampeagle/Snap4.gif" width="647" border="0" />
																<br />第二步</span>
												</b>
												<b style="mso-bidi-font-weight: normal">
														<span lang="EN-US" style="FONT-SIZE: 14pt; FONT-FAMILY: ˎ̥">:</span>
												</b>
												<b style="mso-bidi-font-weight: normal">
														<span lang="EN-US" style="FONT-SIZE: 14pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">
														</span>
												</b>
												<span style="FONT-SIZE: 16pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">产生证书请求<span lang="EN-US">certreq.pem </span>文件<span lang="EN-US"><o:p></o:p></span></span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">使用如下命令：<span lang="EN-US"><o:p></o:p></span></span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">keytool -certreq -alias weblogic -sigalg "MD5withRSA" -file C:/mykeystore/certreq.pem -keypass 123456 -keystore C:/mykeystore/weblogic.jks -storepass 123456</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-size: 16.0pt; mso-bidi-font-family: 宋体">
														<o:p>
														</o:p>
												</span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt; TEXT-ALIGN: left; mso-layout-grid-align: none" align="left">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">
														<o:p>
														</o:p>
												</span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">
														<img height="83" alt="Snap5.gif" src="http://www.blogjava.net/images/blogjava_net/trampeagle/Snap5.gif" width="650" border="0" />
														<br />这样在</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">C:/mykeystore/</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">目录下</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">就会产生一个</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-font-kerning: 0pt; mso-bidi-font-family: 宋体">certreq.pem</span>
												<span style="FONT-SIZE: 12pt; FONT-FAMILY: 宋体; mso-ascii-font-family: ˎ̥; mso-hansi-font-family: ˎ̥">文件，内容如下：</span>
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">
														<o:p>
														</o:p>
												</span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">-----BEGIN NEW CERTIFICATE REQUEST-----<o:p></o:p></span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">MIHlMIGQAgEAMCsxCzAJBgNVBAYTAmNuMQ4wDAYDVQQKEwVlYWdsZTEMMAoGA1UEAxMDaHlxMFww<o:p></o:p></span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">DQYJKoZIhvcNAQEBBQADSwAwSAJBAMhaIG2Ki7+RwZUP4gPBdTbnY38bisW16u1XUyysPxdNwSie<o:p></o:p></span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">aSd6E3Hm277E7NjHoz56ZoaYdPPDmdiTkMrS9rcCAwEAAaAAMA0GCSqGSIb3DQEBBAUAA0EAYRNl<o:p></o:p></span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">l5dyGgV9hhu++ypcJNQTrDIwjx<st1:chmetcnv w:st="on" tcsc="0" numbertype="1" negative="False" hasspace="False" sourcevalue="1" unitname="qt">1QT</st1:chmetcnv>4fgVubrtIaHU0fzHamD5QG6PYddw9TL51XQHvu6tOS0NUc/<o:p></o:p></span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">ItNKJw==<o:p></o:p></span>
										</p>
										<p class="MsoNormal" style="MARGIN: 0cm 0cm 0pt">
												<span lang="EN-US" style="FONT-SIZE: 12pt; FONT-FAMILY: ˎ̥">-----END NEW CERTIFICATE REQUEST-----<br /><br /><strong>第三步：</strong>这就相对来说简单多了，就是<span style="FONT-SIZE: 14pt; FONT-FAMILY: 宋体; mso-hansi-font-family: 'Times New Roman'; mso-bidi-font-family: 宋体; mso-ansi-language: EN-US; mso-fareast-language: ZH-CN; mso-bidi-language: AR-SA">向<span lang="EN-US">CA</span>提交证书请求。<br />    你可以随便从网上找一家免费的CA认证适用机构（很多的），然后按照上面的提示进行操作就可以了，这一步就要用到前面生成的<font size="4"><span lang="EN-US">certreq.pem </span>文件了</font>。（注意：一定要下载根证书）<br />    将生成的证书和下载的根证书放至你比较容易找到的位置，我一般将它们和生成的jks文件放到一起。<br /><br /><strong>第四步：</strong>导入证书<br />    通过命令：keytool -import -alias RootCA -trustcacerts -file C:/mykeystore/RootCADemo.cer -keystore C:/mykeystore/weblogic.jks -storepass 123456将根证书导入第一步生成的weblogic.jks中，接着将所有其它的证书按照此命令全部导入。（<strong>注意</strong>证书的别名不能重复，同时一定<strong>注意</strong>要用上 -trustcacerts，否则，你在以后使用时，它将会认为你导入的这些证书是不可信任的 ，就会导致你在配置SSL时不能正常的工作。）<br />    这就全部完成了<font size="3">密钥仓库</font>的创建。然后就可以在支持这些证书格式的服务器上使用了。下一篇将会写一下在weblogic上如何配置双向SSL</span></span>
										</p>
								</td>
						</tr>
						<tr hb_tag="1" unselectable="on">
								<td style="FONT-SIZE: 1pt" height="1" unselectable="on">
										<div id="hotbar_promo">
										</div>
								</td>
						</tr>
				</tbody>
		</table>
<img src ="http://www.blogjava.net/yrJavaWorld/aggbug/78328.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/yrJavaWorld/" target="_blank">MyJavaWorld</a> 2006-10-31 17:18 <a href="http://www.blogjava.net/yrJavaWorld/archive/2006/10/31/78328.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>DB2数据库中的锁和并发性控制</title><link>http://www.blogjava.net/yrJavaWorld/archive/2006/08/22/65040.html</link><dc:creator>MyJavaWorld</dc:creator><author>MyJavaWorld</author><pubDate>Tue, 22 Aug 2006 04:07:00 GMT</pubDate><guid>http://www.blogjava.net/yrJavaWorld/archive/2006/08/22/65040.html</guid><wfw:comment>http://www.blogjava.net/yrJavaWorld/comments/65040.html</wfw:comment><comments>http://www.blogjava.net/yrJavaWorld/archive/2006/08/22/65040.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/yrJavaWorld/comments/commentRss/65040.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/yrJavaWorld/services/trackbacks/65040.html</trackback:ping><description><![CDATA[现在的DB2 UDB系统中， 主要通过锁和隔离级别这两个主要的工具来控制并发连接，维护数据库中的数据在高并发的环境下的安全。
<p>我们在这里将简要的阐述一下锁和隔离级别。</p><p>锁：</p><p>DB2 UDB中， 锁的主要作用对象是表和行， 其他如表空间和索引也是锁的对象， 但是因为其多为系统控制， 管理员和用户使用较少，在这里就不涉及了。 </p><p>对于行级锁和表级锁， 它们的区别不言而喻， 主要是锁的对象不同。 当然锁对象的不同连带也会影响DB2的并发能力。 </p><p>DB2中的表级锁主要有以下几种：</p><p>1． IS锁： 此锁作用于整个表，表示拥有此锁的应用连接要读取表中的某些数据， 但是在此应用连接读取具体的数据时， 还必须获得该行的行级锁；</p><p>2． IX锁： 此锁作用于整个表，表示拥有此锁的应用连接需要独占使用表中的某些数据， 但是在此应用连接独占使用具体的数据时， 还必须获得该行上相应的行级锁；</p><p>3． SIX锁： 此锁是锁转换的产物，表示应用连接拥有S和IX锁的特性；</p><p>4． S锁： 此锁作用于整个表， 拥有此锁的应用连接可以读取表中的任何纪录；</p><p>5． U锁： 此锁作用于整个表， 拥有此锁的应用连接可以读取表中的任何纪录，也可以更新表中的纪录， 但是更新时需要再获得X锁； 此锁主要在“select … with update”语句建立的可更新游标中起作用， 其他的应用可以读取表中的纪录， 但是不能更新它；</p><p>6． X锁： 此锁作用于整个表， 拥有此锁的应用连接独占的使用表中的任何纪录；可以进行更新或其他操作；</p><p>7． Z锁： 此锁作用于整个表， 也称超级独占锁，主要是在象修改表的定义、 删除表这一类的语句中会使用。 拥有此锁的应用连接对该表有完全的控制权。 其他的任何应用不能读取或更新表中的任何纪录。</p><p>在这里我们主要要看一下 IS/IX/SIX这三个锁。 在这三个锁中IS/IX本身并不具备使得应用连接可以读取或更新纪录的能力，应用连接要读取和更新纪录时， 需要再得到相应的行级锁； 反之亦然， 任何应用要获得行级锁操作数据记录之前， 也必须获得某个相应的表级锁。 SIX锁也是类似的情况。这就是为什麽在很多情况下我们使用的是行级锁， 但是用快照（SNAPSHOT）等工具却能够看到有表级锁存在的原因。</p><p>那麽DB2中又有哪些行级锁呢？ 让我们来看下面的这张图：</p><p><img height="179" alt="那麽DB2中又有哪些行级锁呢？" src="http://www-900.ibm.com/cn/support/nav/images/p23-45-01.jpg" width="400" /><br /><br /></p><p>此图中列出了DB2中包含的行级锁。 表中的第三列指出， 要获得此行级锁之前， 需要预先获得的表级锁， 这里列出的是最低要求。</p><p>这六个行级锁的主要功能如下：</p><p>1． S锁：此行级锁的拥有者可以读取该行的信息； </p><p>2． U锁：此行级锁的拥有者可以读取该行的信息，如果要更新该行，则仍然需要一个行级的X锁；其他的应用只能读取该行的信息；此锁主要是用于FOR UPDATE的游标。</p><p>3． X锁：此行级锁的拥有者可以更新该行的纪录，其他的应用不能连接此行的信息；</p><p>4． W锁：此锁和X锁类似，不同之处是此锁和NW锁兼容；</p><p>5． NS锁：类似于S锁，用于Next Key；</p><p>6． NW锁：类似于W锁，用于Next Key；</p><p>在DB2数据库中， 是通过行级锁和表级锁协调作用来提供较好的并发性， 同时保证数据库中数据的安全。 在DB2中缺省情况下使用行级锁（当然需要IS/IX锁配合），只有当出现锁资源不足， 或者是用命令指定使用表级锁的情况下， 才会在应用连接中使用表级锁。 对锁资源分配有兴趣的读者可以参考DB2的管理手册， 查找其中关于locklist和maxlocks参数的论述。对于用命令指定表级锁的情况， 可以参考DB2的命令手册中的lock table命令， 此命令用于直接锁表。</p><p>隔离级别：</p><p>下面让我们来看一下隔离级别。 隔离级别主要用于控制在DB2根据应用提交的SQL语句向DB2数据库中的相应对象加锁时， 会锁住哪些纪录， 也就是锁定的范围。 隔离级别的不同， 锁定的纪录的范围可能会有很大的差别。</p><p>隔离级别分为RR/RS/CS/UR这四个级别。 下面让我们来逐一论述：</p><p>1． RR隔离级别： 在此隔离级别下， DB2会锁住所有相关的纪录。 在一个SQL语句执行期间， 所有执行此语句扫描过的纪录都会被加上相应的锁。 具体的锁的类型还是由操作的类型来决定， 如果是读取，则加共享锁； 如果是更新， 则加独占锁。 由于会锁定所有为获得SQL语句的结果而扫描的纪录， 所以锁的数量可能会很庞大， 这个时候， 索引的增加可能会对SQL语句的执行有很大的影响，因为索引会影响SQL语句扫描的纪录数量。</p><p>2． RS隔离级别： 此隔离级别的要求比RR隔离级别稍弱，此隔离级别下会锁定所有符合条件的纪录。 不论是读取， 还是更新， 如果SQL语句中包含查询条件， 则会对所有符合条件的纪录加相应的锁。 如果没有条件语句， 也就是对表中的所有记录进行处理，则会对所有的纪录加锁。</p><p>3． CS隔离级别： 此隔离级别仅锁住当前处理的纪录。 </p><p>4． UR隔离级别：此隔离级别下，如果是读取操作，不会出现任何的行级锁。对于非只读的操作，它的锁处理和CS相同。</p><p>在这四种隔离级别中， CS是缺省值。 这四种隔离级别均可以保证DB2数据库在并发的环境下不会有数据丢失的情况发生。 要注意的是如果对纪录进行了修改，需要在相应的纪录上加独占类型的锁， 这些独占类型的锁直到交易结束时才会被释放， 这一点在四种隔离级别下都是相同的。</p><img src ="http://www.blogjava.net/yrJavaWorld/aggbug/65040.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/yrJavaWorld/" target="_blank">MyJavaWorld</a> 2006-08-22 12:07 <a href="http://www.blogjava.net/yrJavaWorld/archive/2006/08/22/65040.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>REORG TABLE</title><link>http://www.blogjava.net/yrJavaWorld/archive/2006/07/26/60257.html</link><dc:creator>MyJavaWorld</dc:creator><author>MyJavaWorld</author><pubDate>Wed, 26 Jul 2006 14:10:00 GMT</pubDate><guid>http://www.blogjava.net/yrJavaWorld/archive/2006/07/26/60257.html</guid><wfw:comment>http://www.blogjava.net/yrJavaWorld/comments/60257.html</wfw:comment><comments>http://www.blogjava.net/yrJavaWorld/archive/2006/07/26/60257.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/yrJavaWorld/comments/commentRss/60257.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/yrJavaWorld/services/trackbacks/60257.html</trackback:ping><description><![CDATA[
		<h3>
				<a name="HDRSQLREORGT">REORG TABLE</a>
		</h3>
		<a name="IDX2498">
		</a>
		<a name="IDX2499">
		</a>
		<a name="IDX2500">
		</a>
		<p>REORG TABLE 语句压缩与指定的表相关联的数据。 
</p>
		<p>
				<b>调用</b>
		</p>
		<p>此语句可以在使用 DB2 CLI 函数的应用程序中使用，也可以通过 CLP 发出。 
</p>
		<p>
				<b>语法</b>
		</p>
		<pre>&gt;&gt;-REORG TABLE--<i>table-name</i>--+------------+---------------------&gt;&lt;
                            '-<i>int1</i>--<i>int2</i>-'
 
 
</pre>
		<p>
				<b>描述</b>
		</p>
		<dl>
				<dt>
						<b>REORG TABLE <var>table-name</var></b>
				</dt>
				<dd>标识重组操作的表。名称必须标识现有的表。 
</dd>
				<dt>
						<b>
								<var>int1</var>
						</b>
				</dt>
				<dd>需要恢复的字节的可选最小百分比。 
</dd>
				<dt>
						<b>
								<var>int2</var>
						</b>
				</dt>
				<dd>需要为将要执行的表压缩恢复的最小字节数。 </dd>
		</dl>
		<p>
				<b>规则</b>
		</p>
		<ul>
				<li>可选的值 <var>int1</var> 和 <var>int2</var> 必须一起使用，或全都不用。 
</li>
				<li>可选的值 <var>int1</var> 必须是非负数。 
</li>
				<li>可选的值 <var>int1</var> 必须介于 0 与 100 之间。 </li>
		</ul>
		<p>
				<b>注意事项</b>
		</p>
		<ul>
				<li>DB2 Everyplace 可以以内部方式调用表重组。 <a name="IDX2501"></a><a name="IDX2502"></a><a name="IDX2503"></a><a name="IDX2504"></a></li>
				<li>第一个可选参数是表必须包含的不可用的字节的百分比（即百分之十（10）意味“至少百分之十的空间不可用”。）第二个可选参数是表必须包含的不可用的字节数（即 1000 将意味“至少 1000 个字节必须是不可用的空间”。）必须符合两个条件，才可以进行表的实际重组。 
</li>
				<li>如果没有指定参数，DB2 Everyplace 对这此选项使用缺省值。缺省百分比是 30 且缺省字节是 6144。因此，“reorg table t1”与“reorg table t1 30 6144”相同。 
</li>
				<li>如果重组方式设置为已启用，则 DB2 Everyplace 将自动重组表。如果在 DELETE 或 UPDATE 上启用了重组，则在执行语句之后，会对目标表执行“reorg table table_name 50 30270”。如果在 DROP TABLE 上启用了重组，则在删除表处理结束时执行“reorg table DB2eSYSTABLES 30 10240”（对于 DB2eSYSCOLUMNS 和 DB2eSYSRELS 也是如此）。 
</li>
				<li>在 C/C++ 程序中，通过使用具有属性 SQL_ATTR_REORG_MODE 的 CLI/ODBC 函数 SQLSetStmtAttr 设置重组方式。在 JAVA 程序中，通过 DB2eStatement 接口 enableReorg 方法设置重组方式。缺省值是启用重组。 
</li>
				<li>重组表时，通过物理上回收删除和更新创建的不可用空间来压缩包含表的数据文件。然后将表的索引更新为指向行的新物理位置。 
</li>
				<li>可以重组“DB2 Everyplace 系统目录”基本表。 
</li>
				<li>在执行 REORG TABLE 语句时，数据库中不应发生任何其它活动。 </li>
		</ul>
		<p>
				<b>示例</b>
		</p>
		<p>使用缺省值压缩 VNNURSE 表。 </p>
		<pre>REORG TABLE VNNURSE 
</pre>
<img src ="http://www.blogjava.net/yrJavaWorld/aggbug/60257.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/yrJavaWorld/" target="_blank">MyJavaWorld</a> 2006-07-26 22:10 <a href="http://www.blogjava.net/yrJavaWorld/archive/2006/07/26/60257.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>DB2 存储过程问题(转)</title><link>http://www.blogjava.net/yrJavaWorld/archive/2006/07/21/59363.html</link><dc:creator>MyJavaWorld</dc:creator><author>MyJavaWorld</author><pubDate>Fri, 21 Jul 2006 02:03:00 GMT</pubDate><guid>http://www.blogjava.net/yrJavaWorld/archive/2006/07/21/59363.html</guid><wfw:comment>http://www.blogjava.net/yrJavaWorld/comments/59363.html</wfw:comment><comments>http://www.blogjava.net/yrJavaWorld/archive/2006/07/21/59363.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/yrJavaWorld/comments/commentRss/59363.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/yrJavaWorld/services/trackbacks/59363.html</trackback:ping><description><![CDATA[&nbsp;&nbsp;&nbsp;&nbsp; 摘要: 在数据库应用程序中使用存储过程有许多好处，包括减少对网络的使用、提高性能以及降低开发成本。Java 存储过程是 DB2 支持的最流行的例程之一。原因之一是，由于 Java 编程语言非常流行，所以 Java 开发人员非常多。因此，在有多种语言可供选择时，Java 例程往往是首选的。										DB2 存储过程不一定非用 Java 来编写。如果业务逻辑只需要简单的存储过程，那么可以考虑用 ...&nbsp;&nbsp;<a href='http://www.blogjava.net/yrJavaWorld/archive/2006/07/21/59363.html'>阅读全文</a><img src ="http://www.blogjava.net/yrJavaWorld/aggbug/59363.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/yrJavaWorld/" target="_blank">MyJavaWorld</a> 2006-07-21 10:03 <a href="http://www.blogjava.net/yrJavaWorld/archive/2006/07/21/59363.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Java正则表达式</title><link>http://www.blogjava.net/yrJavaWorld/archive/2006/07/20/59209.html</link><dc:creator>MyJavaWorld</dc:creator><author>MyJavaWorld</author><pubDate>Thu, 20 Jul 2006 07:48:00 GMT</pubDate><guid>http://www.blogjava.net/yrJavaWorld/archive/2006/07/20/59209.html</guid><wfw:comment>http://www.blogjava.net/yrJavaWorld/comments/59209.html</wfw:comment><comments>http://www.blogjava.net/yrJavaWorld/archive/2006/07/20/59209.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/yrJavaWorld/comments/commentRss/59209.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/yrJavaWorld/services/trackbacks/59209.html</trackback:ping><description><![CDATA[
		<table id="HB_Mail_Container" height="100%" cellspacing="0" cellpadding="0" width="100%" border="0" unselectable="on">
				<tbody>
						<tr height="100%" width="100%" unselectable="on">
								<td id="HB_Focus_Element" valign="top" width="100%" background="" height="250" unselectable="off">
										<h1 class="title">J***A正则表达式</h1>
										<div class="entity">
												<b>关键词</b>： <a href="http://tag.bokee.com/tag/%D5%FD%D4%F2%B1%ED%B4%EF%CA%BD" target="_blank">正则表达式</a>                                           
<p></p><h2 id="header55">正则表达式</h2><p>。正则表达式(regular expression)是<span class="original_words">JDK 1.4</span>的新功能，但是对sed和awk这样的Unix的标准实用工具，以及Python，Perl之类的语言来讲，它早就已经成为其不可或缺的组成部分了(有人甚至认为，它还是Perl能大获成功的最主要的原因)。单从技术角度来讲，正则表达式只是一种处理字符串的工具(过去<span class="original_words">Java</span>这个任务是交由<span class="original_words">String</span>，<span class="original_words">StringBuffer</span>以及<span class="original_words">StringTokenizer</span>处理的)，但是它常常和I/O一起使用，所以放到这里来讲也不算太离题吧。</p><p>正则表达式是一种功能强大但又非常灵活的文本处理工具。它能让你用编程的方式来描述复杂的文本模式，然后在字符串里把它找出来。一旦你找到了这种模式，你就能随心所欲地处理这些文本了。虽然初看起来正则表达式的语法有点让人望而生畏，但它提供了一种精练的动态语言，使我们能用一种通用的方式来解决各种字符串的问题，包括匹配，选择，编辑以及校验。</p><h3 id="header56">创建正则表达式</h3><p>你可以从比较简单的东西入手学习正则表达式。要想全面地掌握怎样构建正则表达式，可以去看<span class="original_words">JDK</span>文档的<span class="original_words">java.util.regex</span>的<span class="original_words">Pattern</span>类的文档。</p><table class="narration" cellspacing="0" bordercolordark="#000000" cellpadding="2" bordercolorlight="#000000" border="2"><tbody><tr><th colspan="2">字符</th></tr><tr><td><span class="original_words">B</span></td><td>字符<span class="original_words">B</span></td></tr><tr><td><span class="original_words">\xhh</span></td><td>16进制值<span class="original_words">0xhh</span>所表示的字符</td></tr><tr><td><span class="original_words">\uhhhh</span></td><td>16进制值<span class="original_words">0xhhhh</span>所表示的Unicode字符</td></tr><tr><td><span class="original_words">\t</span></td><td>Tab</td></tr><tr><td><span class="original_words">\n</span></td><td>换行符</td></tr><tr><td><span class="original_words">\r</span></td><td>回车符</td></tr><tr><td><span class="original_words">\f</span></td><td>换页符</td></tr><tr><td><span class="original_words">\e</span></td><td>Escape</td></tr></tbody></table><p>正则表达式的强大体现在它能定义字符集(character class)。下面是一些最常见的字符集及其定义的方式，此外还有一些预定义的字符集：</p><table class="narration" cellspacing="0" bordercolordark="#000000" cellpadding="2" bordercolorlight="#000000" border="2"><tbody><tr valign="top"><th colspan="2"><span class="original_words">字符集</span></th></tr><tr valign="top"><td valign="top"><span class="original_words">.</span></td><td valign="top">表示任意一个字符 </td></tr><tr valign="top"><td valign="top" width="131"><span class="original_words">[abc]</span></td><td valign="top" width="311">表示字符<span class="original_words">a</span>，<span class="original_words">b</span>，<span class="original_words">c</span>中的任意一个(与<span class="original_words">a|b|c</span>相同) </td></tr><tr valign="top"><td valign="top" width="131"><span class="original_words">[^abc]</span></td><td valign="top" width="311">除<span class="original_words">a</span>，<span class="original_words">b</span>，<span class="original_words">c</span>之外的任意一个字符(否定) </td></tr><tr valign="top"><td valign="top" width="131"><span class="original_words">[a-zA-Z]</span></td><td valign="top" width="311">从<span class="original_words">a</span>到<span class="original_words">z</span>或<span class="original_words">A</span>到<span class="original_words">Z</span>当中的任意一个字符(范围) </td></tr><tr valign="top"><td valign="top" width="131"><span class="original_words">[abc[hij]]</span></td><td valign="top" width="311"><span class="original_words">a,b,c,h,i,j</span>中的任意一个字符(与<span class="original_words">a|b|c|h|i|j</span>相同)(并集) </td></tr><tr valign="top"><td valign="top" width="131"><span class="original_words">[a-z&amp;&amp;[hij]]</span></td><td valign="top" width="311"><span class="original_words">h,i,j</span>中的一个(交集) </td></tr><tr valign="top"><td valign="top" width="131"><span class="original_words">\s</span></td><td valign="top" width="311">空格字符(空格键, tab, 换行, 换页, 回车) </td></tr><tr valign="top"><td valign="top" width="131"><span class="original_words">\S</span></td><td valign="top" width="311">非空格字符(<span class="original_words">[^\s]</span>) </td></tr><tr valign="top"><td valign="top" width="131"><span class="original_words">\d</span></td><td valign="top" width="311">一个数字，也就是<span class="original_words">[0-9]</span></td></tr><tr valign="top"><td valign="top" width="131"><span class="original_words">\D</span></td><td valign="top" width="311">一个非数字的字符，也就是<span class="original_words">[^0-9]</span></td></tr><tr valign="top"><td valign="top" width="131"><span class="original_words">\w</span></td><td valign="top" width="311">一个单词字符(word character)，即<span class="original_words">[a-zA-Z_0-9]</span></td></tr><tr valign="top"><td valign="top" width="131"><span class="original_words">\W</span></td><td valign="top" width="311">一个非单词的字符，<span class="original_words">[^\w]</span></td></tr></tbody></table><p>如果你用过其它语言的正则表达式，那么你一眼就能看出反斜杠的与众不同。在其它语言里，"<span class="original_words">\\</span>"的意思是"我只是要在正则表达式里插入一个反斜杠。没什么特别的意思。"但是在Java里，"<span class="original_words">\\</span>"的意思是"我要插入一个正则表达式的反斜杠，所以跟在它后面的那个字符的意思就变了。"举例来说，如果你想表示一个或更多的"单词字符"，那么这个正则表达式就应该是"<span class="original_words">\\w+</span>"。如果你要插入一个反斜杠，那就得用"<span class="original_words">\\\\</span>"。不过像换行，跳格之类的还是只用一根反斜杠："\n\t"。</p><p>这里只给你讲一个例子；你应该<span class="original_words">JDK</span>文档的<span class="original_words">java.util.regex.Pattern</span>加到收藏夹里，这样就能很容易地找到各种正则表达式的模式了。</p><table class="narration" cellspacing="0" bordercolordark="#000000" cellpadding="2" bordercolorlight="#000000" border="2"><tbody><tr><th colspan="2">逻辑运算符 </th></tr><tr><td>XY</td><td>X 后面跟着 Y</td></tr><tr><td>X|Y</td><td>X或Y</td></tr><tr><td>(X)</td><td>一个"要匹配的组(capturing group)". 以后可以用\i来表示第i个被匹配的组。</td></tr></tbody></table><p></p><table class="narration" cellspacing="0" bordercolordark="#000000" cellpadding="2" bordercolorlight="#000000" border="2"><tbody><tr valign="top"><th valign="top" width="383" colspan="2">边界匹配符 </th></tr><tr valign="top"><td valign="top" width="143"><span class="original_words">^</span></td><td valign="top" width="239">一行的开始 </td></tr><tr valign="top"><td valign="top" width="143"><span class="original_words">$</span></td><td valign="top" width="239">一行的结尾 </td></tr><tr valign="top"><td valign="top" width="143"><span class="original_words">\b</span></td><td valign="top" width="239">一个单词的边界 </td></tr><tr valign="top"><td valign="top" width="143"><span class="original_words">\B</span></td><td valign="top" width="239">一个非单词的边界 </td></tr><tr valign="top"><td valign="top" width="143"><span class="original_words">\G</span></td><td valign="top" width="239">前一个匹配的结束 </td></tr></tbody></table><p>举一个具体一些的例子。下面这些正则表达式都是合法的，而且都能匹配"Rudolph"：</p><blockquote><pre>Rudolph
[rR]udolph
[rR][aeiou][a-z]ol.*
R.*</pre></blockquote><h3 id="header57">数量表示符</h3><p>"数量表示符(quantifier)"的作用是定义模式应该匹配多少个字符。</p><ul><li>Greedy(贪婪的)： 除非另有表示，否则数量表示符都是greedy的。Greedy的表达式会一直匹配下去，直到匹配不下去为止。<u>(如果你发现表达式匹配的结果与预期的不符)</u>，很有可能是因为，你以为表达式会只匹配前面几个字符，而实际上它是greedy的，因此会一直匹配下去。 
</li><li>Reluctant(勉强的)： 用问号表示，它会匹配最少的字符。也称为lazy, minimal matching, non-greedy, 或ungreedy。 
</li><li>Possessive(占有的)： 目前只有Java支持(其它语言都不支持)。它更加先进，所以你可能还不太会用。用正则表达式匹配字符串的时候会产生很多中间状态，<u>(一般的匹配引擎会保存这种中间状态，)</u>这样匹配失败的时候就能原路返回了。占有型的表达式不保存这种中间状态，因此也就不会回头重来了。它能防止正则表达式的失控，同时也能提高运行的效率。 </li></ul><table class="narration" cellspacing="0" bordercolordark="#000000" cellpadding="2" bordercolorlight="#000000" border="2"><tbody><tr valign="top"><th><span class="original_words">Greedy</span></th><th><span class="original_words">Reluctant</span></th><th><span class="original_words">Possessive</span></th><th>匹配 </th></tr><tr valign="top"><td valign="top" width="71"><span class="original_words">X?</span></td><td valign="top" width="86"><span class="original_words">X??</span></td><td valign="top" width="93"><span class="original_words">X?+</span></td><td valign="top" width="231">匹配一个或零个<span class="original_words">X</span></td></tr><tr valign="top"><td valign="top" width="71"><span class="original_words">X*</span></td><td valign="top" width="86"><span class="original_words">X*?</span></td><td valign="top" width="93"><span class="original_words">X*+</span></td><td valign="top" width="231">匹配零或多个<span class="original_words">X</span></td></tr><tr valign="top"><td valign="top" width="71"><span class="original_words">X+</span></td><td valign="top" width="86"><span class="original_words">X+?</span></td><td valign="top" width="93"><span class="original_words">X++</span></td><td valign="top" width="231">匹配一个或多个<span class="original_words">X</span></td></tr><tr valign="top"><td valign="top" width="71"><span class="original_words">X{n}</span></td><td valign="top" width="86"><span class="original_words">X{n}?</span></td><td valign="top" width="93"><span class="original_words">X{n}+</span></td><td valign="top" width="231">匹配正好n个<span class="original_words">X</span></td></tr><tr valign="top"><td valign="top" width="71"><span class="original_words">X{n,}</span></td><td valign="top" width="86"><span class="original_words">X{n,}?</span></td><td valign="top" width="93"><span class="original_words">X{n,}+</span></td><td valign="top" width="231">匹配至少n个<span class="original_words">X</span></td></tr><tr valign="top"><td valign="top" width="71"><span class="original_words">X{n,m}</span></td><td valign="top" width="86"><span class="original_words">X{n,m}?</span></td><td valign="top" width="93"><span class="original_words">X{n,m}+</span></td><td valign="top" width="231">匹配至少n个，至多m个<span class="original_words">X</span></td></tr></tbody></table><p>再提醒一下，要想让表达式照你的意思去运行，你应该用括号把'X'括起来。比方说：</p><blockquote><pre>abc+</pre></blockquote><p>似乎这个表达式能匹配一个或若干个'abc'，但是如果你真的用它去匹配'abcabcabc'的话，实际上只会找到三个字符。因为这个表达式的意思是'ab'后边跟着一个或多个'c'。要想匹配一个或多个完整的'abc'，你应该这样：</p><blockquote><pre>(abc)+</pre></blockquote><p>正则表达式能轻而易举地把你给耍了；这是一种建立在<span class="original_words">Java</span>之上的新语言。</p><h4 id="header58">CharSequence</h4><p>JDK 1.4定义了一个新的接口，叫<span class="original_words">CharSequence</span>。它提供了<span class="original_words">String</span>和<span class="original_words">StringBuffer</span>这两个类的字符序列的抽象：</p><blockquote><pre><font color="#0000ff">interface</font> CharSequence {
  charAt(<font color="#0000ff">int</font> i);
  length();
  subSequence(<font color="#0000ff">int</font> start, <font color="#0000ff">int</font> end);
  toString();
}</pre></blockquote><p>为了实现这个新的<span class="original_words">CharSequence</span>接口，<span class="original_words">String</span>，<span class="original_words">StringBuffer</span>以及<span class="original_words">CharBuffer</span>都作了修改。很多正则表达式的操作都要拿<span class="original_words">CharSequence</span>作参数。</p><h3 id="header59"><span class="original_words">Pattern</span>和<span class="original_words">Matcher</span></h3><p>先给一个例子。下面这段程序可以测试正则表达式是否匹配字符串。第一个参数是要匹配的字符串，后面是正则表达式。正则表达式可以有多个。在Unix/Linux环境下，命令行下的正则表达式还必须用引号。</p><p>当你创建正则表达式时，可以用这个程序来判断它是不是会按照你的要求工作。</p><table class="sourcecode"><tbody><tr><td><pre><font color="#009900">//: c12:TestRegularExpression.java</font><font color="#009900">// Allows you to easly try out regular expressions.</font><font color="#009900">// {Args: abcabcabcdefabc "abc+" "(abc)+" "(abc){2,}" }</font><font color="#0000ff">import</font> java.util.regex.*;
<font color="#0000ff">public</font><font color="#0000ff">class</font> TestRegularExpression {
  <font color="#0000ff">public</font><font color="#0000ff">static</font><font color="#0000ff">void</font> main(String[] args) {
    <font color="#0000ff">if</font>(args.length &lt; 2) {
      System.out.println(<font color="#004488">"Usage:\n"</font> +
        <font color="#004488">"java TestRegularExpression "</font> +
        <font color="#004488">"characterSequence regularExpression+"</font>);
      System.exit(0);
    }
    System.out.println(<font color="#004488">"Input: \"</font><font color="#004488">" + args[0] + "</font>\<font color="#004488">""</font>);
    <font color="#0000ff">for</font>(<font color="#0000ff">int</font> i = 1; i &lt; args.length; i++) {
      System.out.println(
        <font color="#004488">"Regular expression: \"</font><font color="#004488">" + args[i] + "</font>\<font color="#004488">""</font>);
      Pattern p = Pattern.compile(args[i]);
      Matcher m = p.matcher(args[0]);
      <font color="#0000ff">while</font>(m.find()) {
        System.out.println(<font color="#004488">"Match \"</font>" + m.group() +
          <font color="#004488">"\"</font> at positions " +
          m.start() + <font color="#004488">"-"</font> + (m.end() - 1));
      }
    }
  }
} <font color="#009900">///:~</font></pre></td></tr></tbody></table><p><span class="original_words">Java</span>的正则表达式是由<span class="original_words">java.util.regex</span>的<span class="original_words">Pattern</span>和<span class="original_words">Matcher</span>类实现的。<span class="original_words">Pattern</span>对象表示经编译的正则表达式。静态的<span class="original_words">compile( )</span>方法负责将表示正则表达式的字符串编译成<span class="original_words">Pattern</span>对象。正如上述例程所示的，只要给<span class="original_words">Pattern</span>的<span class="original_words">matcher( )</span>方法送一个字符串就能获取一个<span class="original_words">Matcher</span>对象。此外，<span class="original_words">Pattern</span>还有一个能快速判断能否在<span class="original_words">input</span>里面找到<span class="original_words">regex</span>的(注意，原文有误，漏了方法名)</p><blockquote><pre><font color="#0000ff">static</font><font color="#0000ff">boolean</font> matches( regex,  input)</pre></blockquote><p>以及能返回<span class="original_words">String</span>数组的<span class="original_words">split( )</span>方法，它能用<span class="original_words">regex</span>把字符串分割开来。</p><p>只要给<span class="original_words">Pattern.matcher( )</span>方法传一个字符串就能获得<span class="original_words">Matcher</span>对象了。接下来就能用<span class="original_words">Matcher</span>的方法来查询匹配的结果了。</p><blockquote><pre><font color="#0000ff">boolean</font> matches()
<font color="#0000ff">boolean</font> lookingAt()
<font color="#0000ff">boolean</font> find()
<font color="#0000ff">boolean</font> find(<font color="#0000ff">int</font> start)</pre></blockquote><p><span class="original_words">matches( )</span>的前提是<span class="original_words">Pattern</span>匹配整个字符串，而<span class="original_words">lookingAt( )</span>的意思是<span class="original_words">Pattern</span>匹配字符串的开头。 </p><h4 id="header60">find( )</h4><p><span class="original_words">Matcher.find( )</span>的功能是发现<span class="original_words">CharSequence</span>里的，与pattern相匹配的多个字符序列。例如：</p><table class="sourcecode"><tbody><tr><td><pre><font color="#009900">//: c12:FindDemo.java</font><font color="#0000ff">import</font> java.util.regex.*;
<font color="#0000ff">import</font> com.bruceeckel.simpletest.*;
<font color="#0000ff">import</font> java.util.*;
<font color="#0000ff">public</font><font color="#0000ff">class</font> FindDemo {
  <font color="#0000ff">private</font><font color="#0000ff">static</font> Test monitor = <font color="#0000ff">new</font> Test();
  <font color="#0000ff">public</font><font color="#0000ff">static</font><font color="#0000ff">void</font> main(String[] args) {
    Matcher m = Pattern.compile(<font color="#004488">"\\w+"</font>)
      .matcher(<font color="#004488">"Evening is full of the linnet's wings"</font>);
    <font color="#0000ff">while</font>(m.find())
      System.out.println(m.group());
    <font color="#0000ff">int</font> i = 0;
    <font color="#0000ff">while</font>(m.find(i)) {
      System.out.print(m.group() + <font color="#004488">" "</font>);
      i++;
    }
    monitor.expect(<font color="#0000ff">new</font> String[] {
      <font color="#004488">"Evening"</font>,
      <font color="#004488">"is"</font>,
      <font color="#004488">"full"</font>,
      <font color="#004488">"of"</font>,
      <font color="#004488">"the"</font>,
      <font color="#004488">"linnet"</font>,
      <font color="#004488">"s"</font>,
      <font color="#004488">"wings"</font>,
      <font color="#004488">"Evening vening ening ning ing ng g is is s full "</font> +
      <font color="#004488">"full ull ll l of of f the the he e linnet linnet "</font> +
      <font color="#004488">"innet nnet net et t s s wings wings ings ngs gs s "</font>
    });
  }
} <font color="#009900">///:~</font></pre></td></tr></tbody></table><p>"<span class="original_words">\\w+</span>"的意思是"一个或多个单词字符"，因此它会将字符串直接分解成单词。<span class="original_words">find( )</span>像一个迭代器，从头到尾扫描一遍字符串。第二个<span class="original_words">find( )</span>是带<span class="original_words">int</span>参数的，正如你所看到的，它会告诉方法从哪里开始找——即从参数位置开始查找。</p><h4 id="header61">Groups</h4><p>Group是指里用括号括起来的，能被后面的表达式调用的正则表达式。Group 0 表示整个表达式，group 1表示第一个被括起来的group，以此类推。所以；</p><blockquote><pre>A(B(C))D</pre></blockquote><p>里面有三个group：group 0是<span class="original_words">ABCD</span>， group 1是<span class="original_words">BC</span>，group 2是<span class="original_words">C</span>。</p><p>你可以用下述<span class="original_words">Matcher</span>方法来使用group：</p><p><span class="original_words">public int groupCount( )</span>返回matcher对象中的group的数目。不包括group0。</p><p><span class="original_words">public String group( ) </span>返回上次匹配操作(比方说<span class="original_words">find( )</span>)的group 0(整个匹配)</p><p><span class="original_words">public String group(int i)</span>返回上次匹配操作的某个group。如果匹配成功，但是没能找到group，则返回null。</p><p><span class="original_words">public int start(int group)</span>返回上次匹配所找到的，group的开始位置。</p><p><span class="original_words">public int end(int group)</span>返回上次匹配所找到的，group的结束位置，最后一个字符的下标加一。</p><p>下面我们举一些group的例子：</p><table class="sourcecode"><tbody><tr><td><pre><font color="#009900">//: c12:Groups.java</font><font color="#0000ff">import</font> java.util.regex.*;
<font color="#0000ff">import</font> com.bruceeckel.simpletest.*;
<font color="#0000ff">public</font><font color="#0000ff">class</font> Groups {
  <font color="#0000ff">private</font><font color="#0000ff">static</font> Test monitor = <font color="#0000ff">new</font> Test();
  <font color="#0000ff">static</font><font color="#0000ff">public</font><font color="#0000ff">final</font> String poem =
    <font color="#004488">"Twas brillig, and the slithy toves\n"</font> +
    <font color="#004488">"Did gyre and gimble in the wabe.\n"</font> +
    <font color="#004488">"All mimsy were the borogoves,\n"</font> +
    <font color="#004488">"And the mome raths outgrabe.\n\n"</font> +
    <font color="#004488">"Beware the Jabberwock, my son,\n"</font> +
    <font color="#004488">"The jaws that bite, the claws that catch.\n"</font> +
    <font color="#004488">"Beware the Jubjub bird, and shun\n"</font> +
    <font color="#004488">"The frumious Bandersnatch."</font>;
  <font color="#0000ff">public</font><font color="#0000ff">static</font><font color="#0000ff">void</font> main(String[] args) {
    Matcher m =
      Pattern.compile(<font color="#004488">"(?m)(\\S+)\\s+((\\S+)\\s+(\\S+))$"</font>)
        .matcher(poem);
    <font color="#0000ff">while</font>(m.find()) {
      <font color="#0000ff">for</font>(<font color="#0000ff">int</font> j = 0; j &lt;= m.groupCount(); j++)
        System.out.print(<font color="#004488">"["</font> + m.group(j) + <font color="#004488">"]"</font>);
      System.out.println();
    }
    monitor.expect(<font color="#0000ff">new</font> String[]{
      <font color="#004488">"[the slithy toves]"</font> +
      <font color="#004488">"[the][slithy toves][slithy][toves]"</font>,
      <font color="#004488">"[in the wabe.][in][the wabe.][the][wabe.]"</font>,
      <font color="#004488">"[were the borogoves,]"</font> +
      <font color="#004488">"[were][the borogoves,][the][borogoves,]"</font>,
      <font color="#004488">"[mome raths outgrabe.]"</font> +
      <font color="#004488">"[mome][raths outgrabe.][raths][outgrabe.]"</font>,
      <font color="#004488">"[Jabberwock, my son,]"</font> +
      <font color="#004488">"[Jabberwock,][my son,][my][son,]"</font>,
      <font color="#004488">"[claws that catch.]"</font> +
      <font color="#004488">"[claws][that catch.][that][catch.]"</font>,
      <font color="#004488">"[bird, and shun][bird,][and shun][and][shun]"</font>,
      <font color="#004488">"[The frumious Bandersnatch.][The]"</font> +
      <font color="#004488">"[frumious Bandersnatch.][frumious][Bandersnatch.]"</font>
    });
  }
} <font color="#009900">///:~</font></pre></td></tr></tbody></table><p>这首诗是<span class="original_words"><cite>Through the Looking Glass</cite></span>的，Lewis Carroll的"Jabberwocky"的第一部分。可以看到这个正则表达式里有很多用括号括起来的group，它是由任意多个连续的非空字符('<span class="original_words">\S+</span>')和任意多个连续的空格字符('<span class="original_words">\s+</span>')所组成的，其最终目的是要捕获每行的最后三个单词；'<span class="original_words">$</span>'表示一行的结尾。但是'<span class="original_words">$</span>'通常表示整个字符串的结尾，所以这里要明确地告诉正则表达式注意换行符。这一点是由'<span class="original_words">(?m)</span>'标志完成的(模式标志会过一会讲解)。</p><h4 id="header62">start( )和end( )</h4><p>如果匹配成功，<span class="original_words">start( )</span>会返回此次匹配的开始位置，<span class="original_words">end( )</span>会返回此次匹配的结束位置，即最后一个字符的下标加一。如果之前的匹配不成功(或者没匹配)，那么无论是调用<span class="original_words">start( )</span>还是<span class="original_words">end( )</span>，都会引发一个<span class="original_words">IllegalStateException</span>。下面这段程序还演示了<span class="original_words">matches( )</span>和<span class="original_words">lookingAt( )</span>：</p><table class="sourcecode"><tbody><tr><td><pre><font color="#009900">//: c12:StartEnd.java</font><font color="#0000ff">import</font> java.util.regex.*;
<font color="#0000ff">import</font> com.bruceeckel.simpletest.*;
<font color="#0000ff">public</font><font color="#0000ff">class</font> StartEnd {
  <font color="#0000ff">private</font><font color="#0000ff">static</font> Test monitor = <font color="#0000ff">new</font> Test();
  <font color="#0000ff">public</font><font color="#0000ff">static</font><font color="#0000ff">void</font> main(String[] args) {
    String[] input = <font color="#0000ff">new</font> String[] {
      <font color="#004488">"Java has regular expressions in 1.4"</font>,
      <font color="#004488">"regular expressions now expressing in Java"</font>,
      <font color="#004488">"Java represses oracular expressions"</font>
    };
    Pattern
      p1 = Pattern.compile(<font color="#004488">"re\\w*"</font>),
      p2 = Pattern.compile(<font color="#004488">"Java.*"</font>);
    <font color="#0000ff">for</font>(<font color="#0000ff">int</font> i = 0; i &lt; input.length; i++) {
      System.out.println(<font color="#004488">"input "</font> + i + <font color="#004488">": "</font> + input[i]);
      Matcher
        m1 = p1.matcher(input[i]),
        m2 = p2.matcher(input[i]);
      <font color="#0000ff">while</font>(m1.find())
        System.out.println(<font color="#004488">"m1.find() '"</font> + m1.group() +
          <font color="#004488">"' start = "</font>+ m1.start() + <font color="#004488">" end = "</font> + m1.end());
      <font color="#0000ff">while</font>(m2.find())
        System.out.println(<font color="#004488">"m2.find() '"</font> + m2.group() +
          <font color="#004488">"' start = "</font>+ m2.start() + <font color="#004488">" end = "</font> + m2.end());
      <font color="#0000ff">if</font>(m1.lookingAt()) <font color="#009900">// No reset() necessary</font>
        System.out.println(<font color="#004488">"m1.lookingAt() start = "</font>
          + m1.start() + <font color="#004488">" end = "</font> + m1.end());
      <font color="#0000ff">if</font>(m2.lookingAt())
        System.out.println(<font color="#004488">"m2.lookingAt() start = "</font>
          + m2.start() + <font color="#004488">" end = "</font> + m2.end());
      <font color="#0000ff">if</font>(m1.matches()) <font color="#009900">// No reset() necessary</font>
        System.out.println(<font color="#004488">"m1.matches() start = "</font>
          + m1.start() + <font color="#004488">" end = "</font> + m1.end());
      <font color="#0000ff">if</font>(m2.matches())
        System.out.println(<font color="#004488">"m2.matches() start = "</font>
          + m2.start() + <font color="#004488">" end = "</font> + m2.end());
    }
    monitor.expect(<font color="#0000ff">new</font> String[] {
      <font color="#004488">"input 0: Java has regular expressions in 1.4"</font>,
      <font color="#004488">"m1.find() 'regular' start = 9 end = 16"</font>,
      <font color="#004488">"m1.find() 'ressions' start = 20 end = 28"</font>,
      <font color="#004488">"m2.find() 'Java has regular expressions in 1.4'"</font> +
      <font color="#004488">" start = 0 end = 35"</font>,
      <font color="#004488">"m2.lookingAt() start = 0 end = 35"</font>,
      <font color="#004488">"m2.matches() start = 0 end = 35"</font>,
      <font color="#004488">"input 1: regular expressions now "</font> +
      <font color="#004488">"expressing in Java"</font>,
      <font color="#004488">"m1.find() 'regular' start = 0 end = 7"</font>,
      <font color="#004488">"m1.find() 'ressions' start = 11 end = 19"</font>,
      <font color="#004488">"m1.find() 'ressing' start = 27 end = 34"</font>,
      <font color="#004488">"m2.find() 'Java' start = 38 end = 42"</font>,
      <font color="#004488">"m1.lookingAt() start = 0 end = 7"</font>,
      <font color="#004488">"input 2: Java represses oracular expressions"</font>,
      <font color="#004488">"m1.find() 'represses' start = 5 end = 14"</font>,
      <font color="#004488">"m1.find() 'ressions' start = 27 end = 35"</font>,
      <font color="#004488">"m2.find() 'Java represses oracular expressions' "</font> +
      <font color="#004488">"start = 0 end = 35"</font>,
      <font color="#004488">"m2.lookingAt() start = 0 end = 35"</font>,
      <font color="#004488">"m2.matches() start = 0 end = 35"</font>
    });
  }
} <font color="#009900">///:~</font></pre></td></tr></tbody></table><p>注意，只要字符串里有这个模式，<span class="original_words">find( )</span>就能把它给找出来，但是<span class="original_words">lookingAt( )</span>和<span class="original_words">matches( )</span>，只有在字符串与正则表达式一开始就相匹配的情况下才能返回<span class="original_words">true</span>。<span class="original_words">matches( )</span>成功的前提是正则表达式与字符串完全匹配，而<span class="original_words">lookingAt( )</span><a id="ref67" href="mk:@MSITStore:C:\Documents%20and%20Settings\wangkai\桌面\TIJ3_cn.chm::/chap12/nocomment.html#comment67"><sup>[67]</sup></a>成功的前提是，字符串的开始部分与正则表达式相匹配。</p><h4 id="header63">匹配的模式(Pattern flags)</h4><p><span class="original_words">compile( )</span>方法还有一个版本，它需要一个控制正则表达式的匹配行为的参数：</p><blockquote><pre>Pattern Pattern.compile(String regex, <font color="#0000ff">int</font> flag)</pre></blockquote><span class="original_words">flag</span>的取值范围如下： 
<table class="narration" cellspacing="0" bordercolordark="#000000" cellpadding="2" bordercolorlight="#000000" border="2"><tbody><tr><th><span class="original_words">编译标志</span></th><th><span class="original_words">效果</span></th></tr><tr><td><span class="original_words">Pattern.CANON_EQ</span></td><td>当且仅当两个字符的"正规分解(canonical decomposition)"都完全相同的情况下，才认定匹配。比如用了这个标志之后，表达式"a\u030A"会匹配"?"。默认情况下，不考虑"规范相等性(canonical equivalence)"。 </td></tr><tr><td><span class="original_words">Pattern.CASE_INSENSITIVE<br />(?i)</span></td><td>默认情况下，大小写不明感的匹配只适用于US-ASCII字符集。这个标志能让表达式忽略大小写进行匹配。要想对Unicode字符进行大小不明感的匹配，只要将<span class="original_words">UNICODE_CASE</span>与这个标志合起来就行了。 </td></tr><tr><td><span class="original_words">Pattern.COMMENTS<br />(?x)</span></td><td>在这种模式下，匹配时会忽略(正则表达式里的)空格字符(译者注：不是指表达式里的"\\s"，而是指表达式里的空格，tab，回车之类)。注释从#开始，一直到这行结束。可以通过嵌入式的标志来启用Unix行模式。 </td></tr><tr><td><span class="original_words">Pattern.DOTALL<br />(?s)</span></td><td>在这种模式下，表达式'.'可以匹配任意字符，包括表示一行的结束符。默认情况下，表达式'.'不匹配行的结束符。 </td></tr><tr><td><span class="original_words">Pattern.MULTILINE<br />(?m)</span></td><td>在这种模式下，'^'和'$'分别匹配一行的开始和结束。此外，'^'仍然匹配字符串的开始，'$'也匹配字符串的结束。默认情况下，这两个表达式仅仅匹配字符串的开始和结束。 </td></tr><tr><td><span class="original_words">Pattern.UNICODE_CASE<br />(?u)</span></td><td>在这个模式下，如果你还启用了<span class="original_words">CASE_INSENSITIVE</span>标志，那么它会对Unicode字符进行大小写不明感的匹配。默认情况下，大小写不明感的匹配只适用于US-ASCII字符集。 </td></tr><tr><td><span class="original_words">Pattern.UNIX_LINES<br />(?d)</span></td><td>在这个模式下，只有'\n'才被认作一行的中止，并且与'.'，'^'，以及'$'进行匹配。 </td></tr></tbody></table><p>在这些标志里面，<span class="original_words">Pattern.CASE_INSENSITIVE</span>，<span class="original_words">Pattern.MULTILINE</span>，以及<span class="original_words">Pattern.COMMENTS</span>是最有用的(其中<span class="original_words">Pattern.COMMENTS</span>还能帮我们把思路理清楚，并且/或者做文档)。注意，你可以用在表达式里插记号的方式来启用绝大多数的模式。这些记号就在上面那张表的各个标志的下面。你希望模式从哪里开始启动，就在哪里插记号。</p><p>可以用"OR" ('|')运算符把这些标志合使用：</p><table class="sourcecode"><tbody><tr><td><pre><font color="#009900">//: c12:ReFlags.java</font><font color="#0000ff">import</font> java.util.regex.*;
<font color="#0000ff">import</font> com.bruceeckel.simpletest.*;
<font color="#0000ff">public</font><font color="#0000ff">class</font> ReFlags {
  <font color="#0000ff">private</font><font color="#0000ff">static</font> Test monitor = <font color="#0000ff">new</font> Test();
  <font color="#0000ff">public</font><font color="#0000ff">static</font><font color="#0000ff">void</font> main(String[] args) {
    Pattern p =  Pattern.compile(<font color="#004488">"^java"</font>,
      Pattern.CASE_INSENSITIVE | Pattern.MULTILINE);
    Matcher m = p.matcher(
      <font color="#004488">"java has regex\nJava has regex\n"</font> +
      <font color="#004488">"J***A has pretty good regular expressions\n"</font> +
      <font color="#004488">"Regular expressions are in Java"</font>);
    <font color="#0000ff">while</font>(m.find())
      System.out.println(m.group());
    monitor.expect(<font color="#0000ff">new</font> String[] {
      <font color="#004488">"java"</font>,
      <font color="#004488">"Java"</font>,
      <font color="#004488">"J***A"</font>
    });
  }
} <font color="#009900">///:~</font></pre></td></tr></tbody></table><p>这样创建出来的正则表达式就能匹配以"java"，"Java"，"J***A"...开头的字符串了。此外，如果字符串分好几行，那它还会对每一行做匹配(匹配始于字符序列的开始，终于字符序列当中的行结束符)。注意，<span class="original_words">group( )</span>方法仅返回匹配的部分。</p><h3 id="header64">split( )</h3><p>所谓分割是指将以正则表达式为界，将字符串分割成<span class="original_words">String</span>数组。</p><blockquote><pre>String[] split(CharSequence charseq)
String[] split(CharSequence charseq, <font color="#0000ff">int</font> limit)</pre></blockquote><p>这是一种既快又方便地将文本根据一些常见的边界标志分割开来的方法。</p><table class="code"><tbody><tr><td><pre><font color="#009900">//: c12:SplitDemo.java</font><font color="#0000ff">import</font> java.util.regex.*;
<font color="#0000ff">import</font> com.bruceeckel.simpletest.*;
<font color="#0000ff">import</font> java.util.*;
<font color="#0000ff">public</font><font color="#0000ff">class</font> SplitDemo {
  <font color="#0000ff">private</font><font color="#0000ff">static</font> Test monitor = <font color="#0000ff">new</font> Test();
  <font color="#0000ff">public</font><font color="#0000ff">static</font><font color="#0000ff">void</font> main(String[] args) {
    String input =
      <font color="#004488">"This!!unusual use!!of exclamation!!points"</font>;
    System.out.println(Arrays.asList(
      Pattern.compile(<font color="#004488">"!!"</font>).split(input)));
    <font color="#009900">// Only do the first three:</font>
    System.out.println(Arrays.asList(
      Pattern.compile(<font color="#004488">"!!"</font>).split(input, 3)));
    System.out.println(Arrays.asList(
      <font color="#004488">"Aha! String has a split() built in!"</font>.split(<font color="#004488">" "</font>)));
    monitor.expect(<font color="#0000ff">new</font> String[] {
      <font color="#004488">"[This, unusual use, of exclamation, points]"</font>,
      <font color="#004488">"[This, unusual use, of exclamation!!points]"</font>,
      <font color="#004488">"[Aha!, String, has, a, split(), built, in!]"</font>
    });
  }
} <font color="#009900">///:~</font></pre></td></tr></tbody></table><p>第二个<span class="original_words">split( )</span>会限定分割的次数。</p><p>正则表达式是如此重要，以至于有些功能被加进了<span class="original_words">String</span>类，其中包括<span class="original_words">split( )</span>(已经看到了)，<span class="original_words">matches( )</span>，<span class="original_words">replaceFirst( )</span>以及<span class="original_words">replaceAll( )</span>。这些方法的功能同<span class="original_words">Pattern</span>和<span class="original_words">Matcher</span>的相同。 </p><h3 id="header65">替换操作</h3><p>正则表达式在替换文本方面特别在行。下面就是一些方法：</p><p><span class="original_words">replaceFirst(String replacement)</span>将字符串里，第一个与模式相匹配的子串替换成<span class="original_words">replacement</span>。 </p><p><span class="original_words">replaceAll(String replacement)</span>，将输入字符串里所有与模式相匹配的子串全部替换成<span class="original_words">replacement</span>。</p><p><span class="original_words">appendReplacement(StringBuffer sbuf, String replacement)</span>对<span class="original_words">sbuf</span>进行逐次替换，而不是像<span class="original_words">replaceFirst( )</span>或<span class="original_words">replaceAll( )</span>那样，只替换第一个或全部子串。这是个非常重要的方法，因为它可以调用方法来生成<span class="original_words">replacement</span>(<span class="original_words">replaceFirst( )</span>和<span class="original_words">replaceAll( )</span>只允许用固定的字符串来充当<span class="original_words">replacement</span>)。有了这个方法，你就可以编程区分group，从而实现更强大的替换功能。</p><p>调用完<span class="original_words">appendReplacement( )</span>之后，为了把剩余的字符串拷贝回去，必须调用<span class="original_words">appendTail(StringBuffer sbuf, String replacement)</span>。 </p><p>下面我们来演示一下怎样使用这些替换方法。说明一下，这段程序所处理的字符串是它自己开头部分的注释，是用正则表达式提取出来并加以处理之后再传给替换方法的。</p><table class="sourcecode"><tbody><tr><td><pre><font color="#009900">//: c12:TheReplacements.java</font><font color="#0000ff">import</font> java.util.regex.*;
<font color="#0000ff">import</font> java.io.*;
<font color="#0000ff">import</font> com.bruceeckel.util.*;
<font color="#0000ff">import</font> com.bruceeckel.simpletest.*;
<font color="#009900">/*! Here's a block of text to use as input to
    the regular expression matcher. Note that we'll
    first extract the block of text by looking for
    the special delimiters, then process the
    extracted block. !*/</font><font color="#0000ff">public</font><font color="#0000ff">class</font> TheReplacements {
  <font color="#0000ff">private</font><font color="#0000ff">static</font> Test monitor = <font color="#0000ff">new</font> Test();
  <font color="#0000ff">public</font><font color="#0000ff">static</font><font color="#0000ff">void</font> main(String[] args) <font color="#0000ff">throws</font> Exception {
    String s = TextFile.read(<font color="#004488">"TheReplacements.java"</font>);
    <font color="#009900">// Match the specially-commented block of text above:</font>
    Matcher mInput =
      Pattern.compile(<font color="#004488">"</font><font color="#004488">/\\*!(.*)!\\*</font><font color="#004488">/"</font>, Pattern.DOTALL)
        .matcher(s);
    <font color="#0000ff">if</font>(mInput.find())
      s = mInput.group(1); <font color="#009900">// Captured by parentheses</font><font color="#009900">// Replace two or more spaces with a single space:</font>
    s = s.replaceAll(<font color="#004488">" {2,}"</font>, <font color="#004488">" "</font>);
    <font color="#009900">// Replace one or more spaces at the beginning of each</font><font color="#009900">// line with no spaces. Must enable MULTILINE mode:</font>
    s = s.replaceAll(<font color="#004488">"(?m)^ +"</font>, <font color="#004488">""</font>);
    System.out.println(s);
    s = s.replaceFirst(<font color="#004488">"[aeiou]"</font>, <font color="#004488">"(VOWEL1)"</font>);
    StringBuffer sbuf = <font color="#0000ff">new</font> StringBuffer();
    Pattern p = Pattern.compile(<font color="#004488">"[aeiou]"</font>);
    Matcher m = p.matcher(s);
    <font color="#009900">// Process the find information as you</font><font color="#009900">// perform the replacements:</font><font color="#0000ff">while</font>(m.find())
      m.appendReplacement(sbuf, m.group().toUpperCase());
    <font color="#009900">// Put in the remainder of the text:</font>
    m.appendTail(sbuf);
    System.out.println(sbuf);
    monitor.expect(<font color="#0000ff">new</font> String[]{
      <font color="#004488">"Here's a block of text to use as input to"</font>,
      <font color="#004488">"the regular expression matcher. Note that we'll"</font>,
      <font color="#004488">"first extract the block of text by looking for"</font>,
      <font color="#004488">"the special delimiters, then process the"</font>,
      <font color="#004488">"extracted block. "</font>,
      <font color="#004488">"H(VOWEL1)rE's A blOck Of tExt tO UsE As InpUt tO"</font>,
      <font color="#004488">"thE rEgUlAr ExprEssIOn mAtchEr. NOtE thAt wE'll"</font>,
      <font color="#004488">"fIrst ExtrAct thE blOck Of tExt by lOOkIng fOr"</font>,
      <font color="#004488">"thE spEcIAl dElImItErs, thEn prOcEss thE"</font>,
      <font color="#004488">"ExtrActEd blOck. "</font>
    });
  }
} <font color="#009900">///:~</font></pre></td></tr></tbody></table><p>我们用前面介绍的<span class="original_words">TextFile.read( )</span>方法来打开和读取文件。<span class="original_words">mInput</span>的功能是匹配'<span class="original_words">/*!</span>' 和 '<span class="original_words">!*/</span>' 之间的文本(注意一下分组用的括号)。接下来，我们将所有两个以上的连续空格全都替换成一个，并且将各行开头的空格全都去掉(为了让这个正则表达式能对所有的行，而不仅仅是第一行起作用，必须启用多行模式)。这两个操作都用了<span class="original_words">String</span>的<span class="original_words">replaceAll( )</span>(这里用它更方便)。注意，由于每个替换只做一次，因此除了预编译<span class="original_words">Pattern</span>之外，程序没有额外的开销。</p><p><span class="original_words">replaceFirst( )</span>只替换第一个子串。此外，<span class="original_words">replaceFirst( )</span>和<span class="original_words">replaceAll( )</span>只能用常量(literal)来替换，所以如果你每次替换的时候还要进行一些操作的话，它们是无能为力的。碰到这种情况，你得用<span class="original_words">appendReplacement( )</span>，它能让你在进行替换的时候想写多少代码就写多少。在上面那段程序里，创建<span class="original_words">sbuf</span>的过程就是选group做处理，也就是用正则表达式把元音字母找出来，然后换成大写的过程。通常你得在完成全部的替换之后才调用<span class="original_words">appendTail( )</span>，但是如果要模仿<span class="original_words">replaceFirst( )</span>(或"replace n")的效果，你也可以只替换一次就调用<span class="original_words">appendTail( )</span>。它会把剩下的东西全都放进<span class="original_words">sbuf</span>。</p><p>你还可以在<span class="original_words">appendReplacement( )</span>的<span class="original_words">replacement</span>参数里用"$g"引用已捕获的group，其中'g' 表示group的号码。不过这是为一些比较简单的操作准备的，因而其效果无法与上述程序相比。</p><h3 id="header66">reset( )</h3><p>此外，还可以用<span class="original_words">reset( )</span>方法给现有的<span class="original_words">Matcher</span>对象配上个新的<span class="original_words">CharSequence</span>。</p><table class="code"><tbody><tr><td><pre><font color="#009900">//: c12:Resetting.java</font><font color="#0000ff">import</font> java.util.regex.*;
<font color="#0000ff">import</font> java.io.*;
<font color="#0000ff">import</font> com.bruceeckel.simpletest.*;
<font color="#0000ff">public</font><font color="#0000ff">class</font> Resetting {
  <font color="#0000ff">private</font><font color="#0000ff">static</font> Test monitor = <font color="#0000ff">new</font> Test();
  <font color="#0000ff">public</font><font color="#0000ff">static</font><font color="#0000ff">void</font> main(String[] args) <font color="#0000ff">throws</font> Exception {
    Matcher m = Pattern.compile(<font color="#004488">"[frb][aiu][gx]"</font>)
      .matcher(<font color="#004488">"fix the rug with bags"</font>);
    <font color="#0000ff">while</font>(m.find())
      System.out.println(m.group());
    m.reset(<font color="#004488">"fix the rig with rags"</font>);
    <font color="#0000ff">while</font>(m.find())
      System.out.println(m.group());
    monitor.expect(<font color="#0000ff">new</font> String[]{
      <font color="#004488">"fix"</font>,
      <font color="#004488">"rug"</font>,
      <font color="#004488">"bag"</font>,
      <font color="#004488">"fix"</font>,
      <font color="#004488">"rig"</font>,
      <font color="#004488">"rag"</font>
    });
  }
} <font color="#009900">///:~</font></pre></td></tr></tbody></table><p>如果不给参数，<span class="original_words">reset( )</span>会把<span class="original_words">Matcher</span>设到当前字符串的开始处。</p><h3 id="header67">正则表达式与Java I/O</h3><p>到目前为止，你看到的都是用正则表达式处理静态字符串的例子。下面我们来演示一下怎样用正则表达式扫描文件并且找出匹配的字符串。受Unix的grep启发，我写了个<span class="original_words">JGrep.java</span>，它需要两个参数：文件名，以及匹配字符串用的正则表达式。它会把匹配这个正则表达式那部分内容及其所属行的行号打印出来。</p><table class="code"><tbody><tr><td><pre><font color="#009900">//: c12:JGrep.java</font><font color="#009900">// A very simple version of the "grep" program.</font><font color="#009900">// {Args: JGrep.java "\\b[Ssct]\\w+"}</font><font color="#0000ff">import</font> java.io.*;
<font color="#0000ff">import</font> java.util.regex.*;
<font color="#0000ff">import</font> java.util.*;
<font color="#0000ff">import</font> com.bruceeckel.util.*;
<font color="#0000ff">public</font><font color="#0000ff">class</font> JGrep {
  <font color="#0000ff">public</font><font color="#0000ff">static</font><font color="#0000ff">void</font> main(String[] args) <font color="#0000ff">throws</font> Exception {
    <font color="#0000ff">if</font>(args.length &lt; 2) {
      System.out.println(<font color="#004488">"Usage: java JGrep file regex"</font>);
      System.exit(0);
    }
    Pattern p = Pattern.compile(args[1]);
    <font color="#009900">// Iterate through the lines of the input file:</font>
    ListIterator it = <font color="#0000ff">new</font> TextFile(args[0]).listIterator();
    <font color="#0000ff">while</font>(it.hasNext()) {
      Matcher m = p.matcher((String)it.next());
      <font color="#0000ff">while</font>(m.find())
        System.out.println(it.nextIndex() + <font color="#004488">": "</font> +
          m.group() + <font color="#004488">": "</font> + m.start());
    }
  }
} <font color="#009900">///:~</font></pre></td></tr></tbody></table><p>文件是用<span class="original_words">TextFile</span>打开的(本章的前半部分讲的)。由于<span class="original_words">TextFile</span>会把文件的各行放在<span class="original_words">ArrayList</span>里面，而我们又提取了一个<span class="original_words">ListIterator</span>，因此我们可以在文件的各行当中自由移动(既能向前也可以向后)。 </p><p>每行都会有一个<span class="original_words">Matcher</span>，然后用<span class="original_words">find( )</span>扫描。注意，我们用<span class="original_words">ListIterator.nextIndex( )</span>跟踪行号。 </p><p>测试参数是<span class="original_words">JGrep.java</span>和以<span class="original_words">[Ssct]</span>开头的单词。</p><h3 id="header68">还需要StringTokenizer吗?</h3><p>看到正则表达式能提供这么强大的功能，你可能会怀疑，是不是还需要原先的<span class="original_words">StringTokenizer</span>。JDK 1.4以前，要想分割字符串，只有用<span class="original_words">StringTokenizer</span>。但现在，有了正则表达式之后，它就能做得更干净利索了。</p><table class="sourcecode"><tbody><tr><td><pre><font color="#009900">//: c12:ReplacingStringTokenizer.java</font><font color="#0000ff">import</font> java.util.regex.*;
<font color="#0000ff">import</font> com.bruceeckel.simpletest.*;
<font color="#0000ff">import</font> java.util.*;
<font color="#0000ff">public</font><font color="#0000ff">class</font> ReplacingStringTokenizer {
  <font color="#0000ff">private</font><font color="#0000ff">static</font> Test monitor = <font color="#0000ff">new</font> Test();
  <font color="#0000ff">public</font><font color="#0000ff">static</font><font color="#0000ff">void</font> main(String[] args) {
    String input = <font color="#004488">"But I'm not dead yet! I feel happy!"</font>;
    StringTokenizer stoke = <font color="#0000ff">new</font> StringTokenizer(input);
    <font color="#0000ff">while</font>(stoke.hasMoreElements())
      System.out.println(stoke.nextToken());
    System.out.println(Arrays.asList(input.split(<font color="#004488">" "</font>)));
    monitor.expect(<font color="#0000ff">new</font> String[] {
      <font color="#004488">"But"</font>,
      <font color="#004488">"I'm"</font>,
      <font color="#004488">"not"</font>,
      <font color="#004488">"dead"</font>,
      <font color="#004488">"yet!"</font>,
      <font color="#004488">"I"</font>,
      <font color="#004488">"feel"</font>,
      <font color="#004488">"happy!"</font>,
      <font color="#004488">"[But, I'm, not, dead, yet!, I, feel, happy!]"</font>
    });
  }
} <font color="#009900">///:~</font></pre></td></tr></tbody></table><p>有了正则表达式，你就能用更复杂的模式将字符串分割开来——要是交给<span class="original_words">StringTokenizer</span>的话，事情会麻烦得多。我可以很有把握地说，正则表达式可以取代<span class="original_words">StringTokenizer</span>。 </p><p>要想进一步学习正则表达式，建议你看<cite><span class="original_words">Mastering Regular Expression, 2nd Edition</span></cite>，作者Jeffrey E. F. Friedl (O’Reilly, 2002)。</p><h2 id="header69">总结</h2><p>Java的I/O流类库应该能满足你的基本需求：你可以用它来读写控制台，文件，内存，甚至是Internet。你还可以利用继承来创建新的输入和输出类型。你甚至可以利用Java会自动调用对象的<span class="original_words">toString( )</span>方法的特点(Java仅有的"自动类型转换")，通过重新定义这个方法，来对要传给流的对象做一个简单的扩展。</p><p>但是Java的I/O流类库及其文档还是留下了一些缺憾。比方说你打开一个文件往里面写东西，但是这个文件已经有了，这么做会把原先的内容给覆盖了 。这时要是能有一个异常就好了——有些编程语言能让你规定只能往新建的文件里输出。看来Java是要你用<span class="original_words">File</span>对象来判断文件是否存在，因为如果你用<span class="original_words">FileOutputStream</span>或<span class="original_words">FileWriter</span>的话，文件就会被覆盖了。</p><p>我对I/O流类库的评价是比较矛盾的；它确实能干很多事情，而且做到了跨平台。但是如果你不懂decorator模式，就会觉得这种设计太难理解了，所以无论是对老师还是学生，都得多花精力。此外这个类库也不完整，否则我也用不着去写<span class="original_words">TextFile</span>了。此外它没有提供格式化输出的功能，而其他语言都已经提供了这种功能。</p></div>
								</td>
						</tr>
						<tr hb_tag="1" unselectable="on">
								<td style="FONT-SIZE: 1pt" height="1" unselectable="on">
										<div id="hotbar_promo">
										</div>
								</td>
						</tr>
				</tbody>
		</table>
<img src ="http://www.blogjava.net/yrJavaWorld/aggbug/59209.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/yrJavaWorld/" target="_blank">MyJavaWorld</a> 2006-07-20 15:48 <a href="http://www.blogjava.net/yrJavaWorld/archive/2006/07/20/59209.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>