??xml version="1.0" encoding="utf-8" standalone="yes"?>91电影在线播放,99精品综合,毛片在线播放网址http://www.aygfsteel.com/jiujiubuzui/I think I can do itzh-cnThu, 19 Jun 2025 23:19:42 GMTThu, 19 Jun 2025 23:19:42 GMT60寚w分不常见的JAVA关键字的探讨http://www.aygfsteel.com/jiujiubuzui/archive/2010/04/09/317843.html久久不醉久久不醉Fri, 09 Apr 2010 05:47:00 GMThttp://www.aygfsteel.com/jiujiubuzui/archive/2010/04/09/317843.htmlhttp://www.aygfsteel.com/jiujiubuzui/comments/317843.htmlhttp://www.aygfsteel.com/jiujiubuzui/archive/2010/04/09/317843.html#Feedback0http://www.aygfsteel.com/jiujiubuzui/comments/commentRss/317843.htmlhttp://www.aygfsteel.com/jiujiubuzui/services/trackbacks/317843.html
volatileQ?/h5>       Java语言规范中指出:Z获得最佳速度Q允许线E保存共享成员变量的U有拯Q而且只当U程q入或者离开同步代码块时才与׃n成员变量的原始值对比?nbsp;q样当多个线E同时与某个对象交互Ӟ必要注意到要让线E及时的得到׃n成员变量的变化?nbsp;而volatile关键字就是提CVMQ对于这个成员变量不能保存它的私有拷贝,而应直接与共享成员变量交互?nbsp;使用Q在两个或者更多的U程讉K的成员变量上使用volatile。当要访问的变量已在synchronized代码块中Q或者ؓ帔RӞ不必使用?nbsp;    ׃使用volatile屏蔽掉了VM中必要的代码优化Q所以在效率上比较低Q因此一定在必要时才使用此关键字?
Synchronized:
防止多个U程同时讉K相同的代码段?/span>
Transient:
表明cd列化Ӟ变量不必序列化?/span>


久久不醉 2010-04-09 13:47 发表评论
]]>
配置Spring数据?/title><link>http://www.aygfsteel.com/jiujiubuzui/archive/2010/03/03/314404.html</link><dc:creator>久久不醉</dc:creator><author>久久不醉</author><pubDate>Wed, 03 Mar 2010 06:12:00 GMT</pubDate><guid>http://www.aygfsteel.com/jiujiubuzui/archive/2010/03/03/314404.html</guid><wfw:comment>http://www.aygfsteel.com/jiujiubuzui/comments/314404.html</wfw:comment><comments>http://www.aygfsteel.com/jiujiubuzui/archive/2010/03/03/314404.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.aygfsteel.com/jiujiubuzui/comments/commentRss/314404.html</wfw:commentRss><trackback:ping>http://www.aygfsteel.com/jiujiubuzui/services/trackbacks/314404.html</trackback:ping><description><![CDATA[<p>配置一个数据源 <br />     <span id="wmqeeuq" class="hilite1">Spring</span>在第三方依赖包中包含了两个数据源的实现类包,其一是Apache的DBCPQ其二是 C3P0。可以在<span id="wmqeeuq" class="hilite1">Spring</span>配置文g中利用这两者中M一个配|数据源?/p> <p><strong> DBCP数据?/strong> <br />     DBCPcd位于 <spring_home></spring_home>/lib/jakarta-commons/commons-dbcp.jarQDBCP是一个依?Jakarta commons-pool对象池机制的数据库连接池Q所以在c\径下q必d?lt;spring_home></spring_home>/lib/jakarta- commons/commons-pool.jar。下面是使用DBCP<span id="wmqeeuq" class="hilite3">配置</span>MySql数据源的配置片断Q?/p> <div id="wmqeeuq" class="code_title">xml 代码</div> <div id="wmqeeuq" class="dp-highlighter"> <div id="wmqeeuq" class="bar"> <ol class="dp-xml"> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">bean</span><span> </span><span id="wmqeeuq" class="attribute">id</span><span>=</span><span id="wmqeeuq" class="attribute-value">"<span id="wmqeeuq" class="hilite2">dataSource</span>"</span><span> </span><span id="wmqeeuq" class="attribute">class</span><span>=</span><span id="wmqeeuq" class="attribute-value">"org.apache.commons.dbcp.BasicDataSource"</span><span>       </span></span></li> <li><span>        </span><span id="wmqeeuq" class="attribute">destroy-method</span><span>=</span><span id="wmqeeuq" class="attribute-value">"close"</span><span id="wmqeeuq" class="tag">></span><span>       </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"driverClassName"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"com.mysql.jdbc.Driver"</span><span> </span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"url"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"jdbc:mysql://localhost:3309/sampledb"</span><span> </span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"username"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"root"</span><span> </span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"password"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"1234"</span><span> </span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">bean</span><span id="wmqeeuq" class="tag">></span><span>  </span></span></li> </ol> </div> <p>BasicDataSource提供了close()Ҏ关闭数据源,所以必设定destroy-method=”close”属性, 以便<span id="wmqeeuq" class="hilite1">Spring</span>容器关闭Ӟ数据源能够正常关闭。除以上必须的数据源属性外Q还有一些常用的属性: <br />     defaultAutoCommitQ设|从数据源中q回的连接是否采用自动提交机Ӟ默认gؓ trueQ?<br />     defaultReadOnlyQ设|数据源是否仅能执行只读操作Q?默认gؓ falseQ?<br />     maxActiveQ最大连接数据库q接敎ͼ讄?Ӟ表示没有限制Q?<br />     maxIdleQ最大等待连接中的数量,讄?Ӟ表示没有限制Q?<br />     maxWaitQ最大等待秒敎ͼ单位为毫U, 过旉会报出错误信息; <br />     validationQueryQ用于验证连接是否成功的查询SQL语句QSQL语句必须臛_要返回一行数据, 如你可以单地讄为:“select count(*) from user”Q?<br />     removeAbandonedQ是否自我中断,默认?false Q?<br />     removeAbandonedTimeoutQ几U后数据q接会自动断开Q在removeAbandoned为trueQ提供该| <br />     logAbandonedQ是否记录中断事Ӟ 默认?falseQ?</p> <p><strong>C3P0数据?/strong> <br />     C3P0是一个开放源代码的JDBC数据源实现项目,它在lib目录中与Hibernate一起发布,实现了JDBC3和JDBC2扩展规范说明?Connection 和Statement 池。C3P0cd位于<spring_home></spring_home>/lib/c3p0/c3p0-0.9.0.4.jar。下面是使用C3P0配置一?Oracle数据源:</p> <div id="wmqeeuq" class="code_title">xml 代码</div> <div id="wmqeeuq" class="dp-highlighter"> <div id="wmqeeuq" class="bar"> <ol class="dp-xml"> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">bean</span><span> </span><span id="wmqeeuq" class="attribute">id</span><span>=</span><span id="wmqeeuq" class="attribute-value">"<span id="wmqeeuq" class="hilite2">dataSource</span>"</span><span> </span><span id="wmqeeuq" class="attribute">class</span><span>=</span><span id="wmqeeuq" class="attribute-value">"com.mchange.v2.c3p0.ComboPooledDataSource"</span><span>       </span></span></li> <li><span>        </span><span id="wmqeeuq" class="attribute">destroy-method</span><span>=</span><span id="wmqeeuq" class="attribute-value">"close"</span><span id="wmqeeuq" class="tag">></span><span>      </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"driverClass"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">" oracle.jdbc.driver.OracleDriver "</span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"jdbcUrl"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">" jdbc:oracle:thin:@localhost:1521:ora9i "</span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"user"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"admin"</span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"password"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"1234"</span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">bean</span><span id="wmqeeuq" class="tag">></span><span>  </span></span></li> </ol> </div> <p>ComboPooledDataSource和BasicDataSource一h供了一个用于关闭数据源的close()ҎQ这h们就可以保证<span id="wmqeeuq" class="hilite1">Spring</span>容器关闭时数据源能够成功释放?<br />     C3P0拥有比DBCP更丰富的配置属性,通过q些属性,可以Ҏ据源q行各种有效的控Ӟ <br />     acquireIncrementQ当q接池中的连接用完时QC3P0一ơ性创建新q接的数目; <br />     acquireRetryAttemptsQ定义在从数据库获取新连接失败后重复试获取的次敎ͼ默认?0Q?<br />     acquireRetryDelayQ两ơ连接中间隔旉Q单位毫U,默认?000Q?<br />     autoCommitOnCloseQ连接关闭时默认所有未提交的操作回滚。默认ؓfalseQ?<br />     automaticTestTableQ?C3P0徏一张名为Test的空表,q用其自带的查询语句进行测试。如果定义了q个参数Q那么属性preferredTestQuery被忽略。你 不能在这张Test表上q行M操作Q它中为C3P0试所用,默认为nullQ?<br />     breakAfterAcquireFailureQ获取连接失败将会引h有等待获取连接的U程抛出异常。但是数据源仍有效保留,q在下次?nbsp;  用getConnection()的时候l尝试获取连接。如果设为trueQ那么在试获取q接p|后该数据源将x已断开q永久关闭。默认ؓ falseQ?<br />     checkoutTimeoutQ当q接池用完时客户端调用getConnection()后等待获取新q接的时_时后将抛出SQLExceptionQ如设ؓ0则无限期{待。单位毫U,默认?Q?<br />     connectionTesterClassNameQ?通过实现ConnectionTester或QueryConnectionTester的类来测试连接,cd需讄为全限定名。默认ؓ com.mchange.v2.C3P0.impl.DefaultConnectionTesterQ?nbsp;<br />     idleConnectionTestPeriodQ隔多少U检查所有连接池中的I闲q接Q默认ؓ0表示不检查; <br />     initialPoolSizeQ初始化时创建的q接敎ͼ应在minPoolSize与maxPoolSize之间取倹{默认ؓ3Q?<br />     maxIdleTimeQ最大空闲时_过I闲旉的连接将被丢弃。ؓ0或负数则怸丢弃。默认ؓ0Q?<br />     maxPoolSizeQ连接池中保留的最大连接数。默认ؓ15Q?<br />     maxStatementsQJDBC的标准参敎ͼ用以控制数据源内加蝲的PreparedStatement数量。但׃预缓存的Statement?于单个Connection而不是整个连接池。所以设|这个参数需要考虑到多斚w的因素,如果maxStatements?maxStatementsPerConnection均ؓ0Q则~存被关闭。默认ؓ0Q?<br />     maxStatementsPerConnectionQ连接池内单个连接所拥有的最大缓存Statement数。默认ؓ0Q?<br />     numHelperThreadsQC3P0是异步操作的Q缓慢的JDBC操作通过帮助q程完成。扩展这些操作可以有效的提升性能Q通过多线E实现多个操作同时被执行。默认ؓ3Q?<br />     preferredTestQueryQ定义所有连接测试都执行的测试语句。在使用q接试的情况下q个参数能显著提高测试速度。测试的表必d初始数据源的时候就存在。默认ؓnullQ?<br />     propertyCycleQ?用户修改pȝ配置参数执行前最多等待的U数。默认ؓ300Q?<br />     testConnectionOnCheckoutQ因性能消耗大请只在需要的时候用它。如果设为true那么在每个connection提交的时候都 校验其有效性。徏议用idleConnectionTestPeriod或automaticTestTable <br /> {方法来提升q接试的性能。默认ؓfalseQ?<br />     testConnectionOnCheckinQ如果设为true那么在取得连接的同时校验连接的有效性。默认ؓfalse?<br /> <br /> <strong>读配|文件的方式引用属性: </strong></p> <div id="wmqeeuq" class="dp-highlighter"> <div id="wmqeeuq" class="bar"> <ol class="dp-xml"> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">bean</span><span> </span><span id="wmqeeuq" class="attribute">id</span><span>=</span><span id="wmqeeuq" class="attribute-value">"propertyConfigurer"</span><span>     </span></span></li> <li><span>        </span><span id="wmqeeuq" class="attribute">class</span><span>=</span><span id="wmqeeuq" class="attribute-value">"org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"</span><span id="wmqeeuq" class="tag">></span><span>      </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"location"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"/WEB-INF/jdbc.properties"</span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li><span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">bean</span><span id="wmqeeuq" class="tag">></span><span>      </span></span></li> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">bean</span><span> </span><span id="wmqeeuq" class="attribute">id</span><span>=</span><span id="wmqeeuq" class="attribute-value">"<span id="wmqeeuq" class="hilite2">dataSource</span>"</span><span> </span><span id="wmqeeuq" class="attribute">class</span><span>=</span><span id="wmqeeuq" class="attribute-value">"org.apache.commons.dbcp.BasicDataSource"</span><span>       </span></span></li> <li><span>        </span><span id="wmqeeuq" class="attribute">destroy-method</span><span>=</span><span id="wmqeeuq" class="attribute-value">"close"</span><span id="wmqeeuq" class="tag">></span><span>      </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"driverClassName"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"${jdbc.driverClassName}"</span><span> </span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"url"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"${jdbc.url}"</span><span> </span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"username"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"${jdbc.username}"</span><span> </span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"password"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"${jdbc.password}"</span><span> </span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">bean</span><span id="wmqeeuq" class="tag">></span><span>   </span></span></li> </ol> </div> <p>    在jdbc.properties属性文件中定义属性| <br />     jdbc.driverClassName= com.mysql.jdbc.Driver <br />     jdbc.url= jdbc:mysql://localhost:3309/sampledb <br />     jdbc.username=root <br />     jdbc.password=1234 <br />     提示 l常有开发者在${xxx}的前后不心键入一些空|q些I格字符和变量合ƈ后作为属性的倹{如Q?<property name="username" value=" ${jdbc.username} "></property> 的属性配|项Q在前后都有I格Q被解析后,username的gؓ“ 1234 ”Q这造成最l的错误Q因此需要特别小心?br /> <br /> <strong> 获取JNDI数据?/strong> <br />     如果应用配置在高性能的应用服务器Q如WebLogic或Websphere{)上,我们可能更希望用应用服务器本n提供的数据源。应用服务器的数据源 使用JNDI开放调用者用,Spring为此专门提供引用JNDI资源的JndiObjectFactoryBeancR下面是一个简单的配置Q?/p> <div id="wmqeeuq" class="code_title">xml 代码</div> <div id="wmqeeuq" class="dp-highlighter"> <div id="wmqeeuq" class="bar"> <ol class="dp-xml"> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">bean</span><span> </span><span id="wmqeeuq" class="attribute">id</span><span>=</span><span id="wmqeeuq" class="attribute-value">"dataSource"</span><span> </span><span id="wmqeeuq" class="attribute">class</span><span>=</span><span id="wmqeeuq" class="attribute-value">"org.springframework.jndi.JndiObjectFactoryBean"</span><span id="wmqeeuq" class="tag">></span><span>      </span></span></li> <li><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"jndiName"</span><span> </span><span id="wmqeeuq" class="attribute">value</span><span>=</span><span id="wmqeeuq" class="attribute-value">"java:comp/env/jdbc/bbt"</span><span id="wmqeeuq" class="tag">/></span><span>      </span></li> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">bean</span><span id="wmqeeuq" class="tag">></span><span>  </span></span></li> </ol> </div> <p>通过jndiName指定引用的JNDI数据源名U?<br />     Spring 2.0取J2EE资源提供了一个jee命名I间Q通过jee命名I间Q可以有效地化J2EE资源的引用。下面是使用jee命名I间引用JNDI数据源的配置Q?</p> <div id="wmqeeuq" class="code_title">xml 代码</div> <div id="wmqeeuq" class="dp-highlighter"> <div id="wmqeeuq" class="bar"> <ol class="dp-xml"> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">beans</span><span> </span><span id="wmqeeuq" class="attribute">xmlns</span><span>=</span><span id="wmqeeuq" class="attribute-value">http</span><span>://www.springframework.org/schema/beans    </span></span></li> <li><span><span id="wmqeeuq" class="attribute">xmlns:xsi</span><span>=</span><span id="wmqeeuq" class="attribute-value">http</span><span>://www.w3.org/2001/XMLSchema-instance    </span></span></li> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="attribute">xmlns:jee</span><span>=</span><span id="wmqeeuq" class="attribute-value">http</span><span>://www.springframework.org/schema/jee    </span></span></li> <li><span><span id="wmqeeuq" class="attribute">xsi:schemaLocation</span><span>="http://www.springframework.org/schema/beans     </span></span></li> <li id="wmqeeuq" class="alt"><span>http://www.springframework.org/schema/beans/spring-beans-2.0.xsd     </span></li> <li><span>http://www.springframework.org/schema/jee    </span></li> <li id="wmqeeuq" class="alt"><span>http://www.springframework.org/schema/jee/spring-jee-2.0.xsd"</span><span id="wmqeeuq" class="tag">></span><span>      </span></li> <li><span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">jee:jndi-lookup</span><span> </span><span id="wmqeeuq" class="attribute">id</span><span>=</span><span id="wmqeeuq" class="attribute-value">"dataSource"</span><span> </span><span id="wmqeeuq" class="attribute">jndi-name</span><span>=</span><span id="wmqeeuq" class="attribute-value">" java:comp/env/jdbc/bbt"</span><span id="wmqeeuq" class="tag">/></span><span>      </span></span></li> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">beans</span><span id="wmqeeuq" class="tag">></span><span>  </span></span></li> </ol> </div> <p><font size="+0">Spring的数据源实现c?<br />     Spring本n也提供了一个简单的数据源实现类DriverManagerDataSource Q它位于org.springframework.jdbc.datasource包中。这个类实现了javax.sql.DataSource接口Q但 它ƈ没有提供池化q接的机Ӟ每次调用getConnection()获取新连接时Q只是简单地创徏一个新的连接。因此,q个数据源类比较适合在单元测?或简单的独立应用中用,因ؓ它不需要额外的依赖cR?<br />      下面Q我们来看一下DriverManagerDataSource的简单用:</font><font size="+0">当然Q我们也可以通过配置的方式直接用DriverManagerDataSource?/font></p> <div id="wmqeeuq" class="code_title">java 代码</div> <div id="wmqeeuq" class="dp-highlighter"> <div id="wmqeeuq" class="bar"> <ol class="dp-j"> <li id="wmqeeuq" class="alt"><span><span>DriverManagerDataSource ds = </span><span id="wmqeeuq" class="keyword">new</span><span> DriverManagerDataSource ();      </span></span></li> <li><span>ds.setDriverClassName(</span><span id="wmqeeuq" class="string">"com.mysql.jdbc.Driver"</span><span>);      </span></li> <li id="wmqeeuq" class="alt"><span>ds.setUrl(</span><span id="wmqeeuq" class="string">"jdbc:mysql://localhost:3309/sampledb"</span><span>);      </span></li> <li><span>ds.setUsername(</span><span id="wmqeeuq" class="string">"root"</span><span>);      </span></li> <li id="wmqeeuq" class="alt"><span>ds.setPassword(</span><span id="wmqeeuq" class="string">"1234"</span><span>);      </span></li> <li><span>Connection actualCon = ds.getConnection();  </span></li> </ol> </div> <p> </p> <p><font size="+0"><strong>结</strong> </font></p> <p><font size="+0">    不管采用何种持久化技术,都需要定义数据源。Spring附带了两个数据源的实现类包,你可以自行选择q行定义。在实际部vӞ我们可能会直接采用应用服 务器本n提供的数据源Q这Ӟ则可以通过JndiObjectFactoryBean或jee命名I间引用JNDI中的数据源?</font></p> <p><font size="+0">DBCP与C3PO配置的区别:</font></p> <p><font size="+0">C3PO Q?/font><font size="+0">DBCPQ?/font></p> <div id="wmqeeuq" class="code_title">xml 代码</div> <div id="wmqeeuq" class="dp-highlighter"> <div id="wmqeeuq" class="bar"> <ol class="dp-xml"> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">bean</span><span> </span><span id="wmqeeuq" class="attribute">id</span><span>=</span><span id="wmqeeuq" class="attribute-value">"dataSource"</span><span> </span><span id="wmqeeuq" class="attribute">class</span><span>=</span><span id="wmqeeuq" class="attribute-value">"com.mchange.v2.c3p0.ComboPooledDataSource"</span><span> </span><span id="wmqeeuq" class="attribute">destroy-method</span><span>=</span><span id="wmqeeuq" class="attribute-value">"close"</span><span id="wmqeeuq" class="tag">></span><span>  </span></span></li> <li><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"driverClass"</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>        </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>oracle.jdbc.driver.OracleDriver</span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">property</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"jdbcUrl"</span><span id="wmqeeuq" class="tag">></span><span>             </span></li> <li><span>        </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>jdbc:oracle:thin:@10.10.10.6:1521:DataBaseName</span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>     </span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">property</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"user"</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>        </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>testAdmin</span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">property</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"password"</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li><span>        </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>123456</span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">property</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li><span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">bean</span><span id="wmqeeuq" class="tag">></span><span>  </span></span></li> </ol> </div> <p> </p> <div id="wmqeeuq" class="code_title">xml 代码</div> <div id="wmqeeuq" class="dp-highlighter"> <div id="wmqeeuq" class="bar"> <ol class="dp-xml"> <li id="wmqeeuq" class="alt"><span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">bean</span><span> </span><span id="wmqeeuq" class="attribute">id</span><span>=</span><span id="wmqeeuq" class="attribute-value">"dataSource"</span><span> </span><span id="wmqeeuq" class="attribute">class</span><span>=</span><span id="wmqeeuq" class="attribute-value">"org.apache.commons.dbcp.BasicDataSource"</span><span> </span><span id="wmqeeuq" class="attribute">destroy-method</span><span>=</span><span id="wmqeeuq" class="attribute-value">"close"</span><span id="wmqeeuq" class="tag">></span><span>  </span></span></li> <li><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"driverClassName"</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>        </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>oracle.jdbc.driver.OracleDriver</span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">property</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"url"</span><span id="wmqeeuq" class="tag">></span><span>             </span></li> <li><span>        </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>jdbc:oracle:thin:@10.10.10.6:1521:DataBaseName</span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>     </span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">property</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"username"</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>        </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>testAdmin</span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li><span>    </span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">property</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">property</span><span> </span><span id="wmqeeuq" class="attribute">name</span><span>=</span><span id="wmqeeuq" class="attribute-value">"password"</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li><span>        </span><span id="wmqeeuq" class="tag"><</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>123456</span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">value</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li id="wmqeeuq" class="alt"><span>    </span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">property</span><span id="wmqeeuq" class="tag">></span><span>  </span></li> <li><span><span id="wmqeeuq" class="tag"></</span><span id="wmqeeuq" class="tag-name">bean</span><span id="wmqeeuq" class="tag">></span><span>  </span></span></li> </ol> </div> </div> </div> </div> </div> </div> </div> </div> </div><img src ="http://www.aygfsteel.com/jiujiubuzui/aggbug/314404.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.aygfsteel.com/jiujiubuzui/" target="_blank">久久不醉</a> 2010-03-03 14:12 <a href="http://www.aygfsteel.com/jiujiubuzui/archive/2010/03/03/314404.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>(?oracle xe 手工建立ZHS16GBK字符集数据库http://www.aygfsteel.com/jiujiubuzui/archive/2009/12/28/307520.html久久不醉久久不醉Mon, 28 Dec 2009 07:17:00 GMThttp://www.aygfsteel.com/jiujiubuzui/archive/2009/12/28/307520.htmlhttp://www.aygfsteel.com/jiujiubuzui/comments/307520.htmlhttp://www.aygfsteel.com/jiujiubuzui/archive/2009/12/28/307520.html#Feedback0http://www.aygfsteel.com/jiujiubuzui/comments/commentRss/307520.htmlhttp://www.aygfsteel.com/jiujiubuzui/services/trackbacks/307520.htmloracle xe universal默认创徏AL32UTF8字符?q种字符?个汉字占?个字节,?br /> ZHS16GBK字符?个汉字占?个字节,Z节约I间Q我试改变数据库的字符集,
但是p|了,因ؓ新字W集不是旧字W集的超集。即使用restrict模式也不行?br /> 考虑到oracle xe 安装时只是徏一个空库,仅包含系l表I间{,设想通过手工执行
创徏ZHS16GBK字符集数据库的办法实现?br /> 从sybex?0g ocp教材中复制ƈ修改得下面语句,其中E:\ORADATA\TEST是我们要存放
新数据库物理文g的目录,以和旧数据库区分?/span>


CREATE DATABASE XE
CONTROLFILE REUSE
LOGFILE
GROUP 1 'E:\ORADATA\TEST\REDO01.LOG' SIZE 10M,
GROUP 2 'E:\ORADATA\TEST\REDO02.LOG' SIZE 10M,
GROUP 3 'E:\ORADATA\TEST\REDO03.LOG' SIZE 10M
DATAFILE 'E:\ORADATA\TEST\SYSTEM01.DBF' SIZE 400M
AUTOEXTEND ON NEXT 50M MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL
SYSAUX DATAFILE 'E:\ORADATA\TEST\SYSAUX01.DBF' SIZE 250M
AUTOEXTEND ON NEXT 50M MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL
DEFAULT TEMPORARY TABLESPACE temp
TEMPFILE 'E:\ORADATA\TEST\TEMP01.DBF' SIZE 100M
AUTOEXTEND ON NEXT 100M MAXSIZE 8000M
UNDO TABLESPACE undo
DATAFILE 'E:\ORADATA\TEST\undo01.DBF' SIZE 200M
AUTOEXTEND ON NEXT 100M MAXSIZE UNLIMITED EXTENT MANAGEMENT LOCAL
CHARACTER SET ZHS16GBK
NATIONAL CHARACTER SET AL16UTF16
USER SYS IDENTIFIED BY SYS
USER SYSTEM IDENTIFIED BY SYS
;
在执行这个脚本以前,?点要注意Q?br /> 1 要修改F:\oraclexe\app\oracle\product\10.2.0\server\config\scripts\init.ora'
?br /> F:\oraclexe\app\oracle\product\10.2.0\server\config\scripts\test.ora'
把所有\径改成E:\ORADATA\TEST及其子目?为此我们需要在E:\ORADATA\TEST下徏?br /> bdump{目?q些目录可以从现有的XE数据库F:\oraclexe\app\oracle\admin\XE复制得到?/span>

2 要去掉EXTENT MANAGEMENT LOCAL语句否则执行出错。(没有扑և原因Q?/span>

CREATE DATABASE XE
*
W?1 行出现错?
ORA-25146: EXTENT MANAGEMENT ?????

3 test.ora中的db_name不能改变Q否则执行出错。(没有扑և原因Q?br /> ORA-02778: Name given for the log directory is invalid

具体执行步骤Q以Windows XPZQ?br /> 1在cmd命o行窗口执?net start oracleservicexe
C:\Documents and Settings\Administrator>net start oracleservicexe
OracleServiceXE 服务正在启动 .........
OracleServiceXE 服务已经启动成功?/span>

2 以sys用户d
C:\Documents and Settings\Administrator>sqlplus /nolog

SQL*Plus: Release 10.2.0.1.0 - Production on 星期?5?30 22:07:45 2006

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

SQL> conn / as sysdba
已连接?br /> 3 查看现有的字W集讄
SQL> set lines 140
SQL> select * from nls_database_parameters;

PARAMETER
------------------------------------------------------------
VALUE
-------------------------------------------------------------------
------------------------------------------------------------
NLS_LANGUAGE
AMERICAN

NLS_TERRITORY
AMERICA

NLS_CURRENCY
$

NLS_ISO_CURRENCY
AMERICA

NLS_NUMERIC_CHARACTERS
.,

NLS_CHARACTERSET
AL32UTF8

NLS_CALENDAR
GREGORIAN

NLS_DATE_FORMAT
DD-MON-RR

NLS_DATE_LANGUAGE
AMERICAN

NLS_SORT
BINARY

NLS_TIME_FORMAT
HH.MI.SSXFF AM

NLS_TIMESTAMP_FORMAT
DD-MON-RR HH.MI.SSXFF AM

NLS_TIME_TZ_FORMAT
HH.MI.SSXFF AM TZR

NLS_TIMESTAMP_TZ_FORMAT
DD-MON-RR HH.MI.SSXFF AM TZR

NLS_DUAL_CURRENCY
$

NLS_COMP
BINARY

NLS_LENGTH_SEMANTICS
BYTE

NLS_NCHAR_CONV_EXCP
FALSE

NLS_NCHAR_CHARACTERSET
AL16UTF16

NLS_RDBMS_VERSION
10.2.0.1.0


已选择20行?/span>

SQL> select lengthb('?) from dual;

LENGTHB('?)
-------------
            3

已选择 1 行?/span>

我们可以看到Q当前AL32UTF8字符?个汉字占?个字?br /> 4 关闭数据库,但不停止服务
QL> shutdown immediate
数据库已l关闭?br /> 已经卸蝲数据库?br /> ORACLE 例程已经关闭?br /> 5 用修改过的pfile test.ora启动数据库(nomountQ?br /> SQL> startup nomount pfile='F:\oraclexe\app\oracle\product\10.2.0\server\config\scripts\test.ora'
ORACLE 例程已经启动?/span>

Total System Global Area  285212672 bytes
Fixed Size                  1287016 bytes
Variable Size              92277912 bytes
Database Buffers          188743680 bytes
Redo Buffers                2904064 bytes
6 执行建立数据库脚?br /> SQL> CREATE DATABASE XE
  2  CONTROLFILE REUSE
  3  LOGFILE
  4  GROUP 1 'E:\ORADATA\TEST\REDO01.LOG' SIZE 10M,
  5  GROUP 2 'E:\ORADATA\TEST\REDO02.LOG' SIZE 10M,
  6  GROUP 3 'E:\ORADATA\TEST\REDO03.LOG' SIZE 10M
  7  DATAFILE 'E:\ORADATA\TEST\SYSTEM01.DBF' SIZE 400M
  8  AUTOEXTEND ON NEXT 50M MAXSIZE UNLIMITED
  9  SYSAUX DATAFILE 'E:\ORADATA\TEST\SYSAUX01.DBF' SIZE 250M
 10  AUTOEXTEND ON NEXT 50M MAXSIZE UNLIMITED
 11  DEFAULT TEMPORARY TABLESPACE temp
 12  TEMPFILE 'E:\ORADATA\TEST\TEMP01.DBF' SIZE 100M
 13  AUTOEXTEND ON NEXT 100M MAXSIZE 8000M
 14  UNDO TABLESPACE undo
 15  DATAFILE 'E:\ORADATA\TEST\undo01.DBF' SIZE 200M
 16  AUTOEXTEND ON NEXT 100M MAXSIZE UNLIMITED
 17  CHARACTER SET ZHS16GBK
 18  NATIONAL CHARACTER SET AL16UTF16
 19  USER SYS IDENTIFIED BY SYS
 20  USER SYSTEM IDENTIFIED BY SYS
 21  ;

数据库已创徏?br /> 7 执行创徏数据字典和程序包的系lSQL脚本
@F:\oraclexe\app\oracle\product\10.2.0\server\RDBMS\ADMIN\catalog.sql
@F:\oraclexe\app\oracle\product\10.2.0\server\RDBMS\ADMIN\catproc.sql
大约需?0几分?br /> 8 关闭数据库,但不停止服务
SQL> shutdown immediate
数据库已l关闭?br /> 已经卸蝲数据库?br /> ORACLE 例程已经关闭?br /> 9 用修改过的pfile test.ora启动数据?br /> SQL> startup  pfile='F:\oraclexe\app\oracle\product\10.2.0\server\config\scripts\test.ora'
ORACLE 例程已经启动?/span>

Total System Global Area  285212672 bytes
Fixed Size                  1287016 bytes
Variable Size              92277912 bytes
Database Buffers          188743680 bytes
Redo Buffers                2904064 bytes
数据库装载完毕?br /> 数据库已l打开?br /> 10 查看新徏数据库的字符集设|?br /> SQL> set lines 140
SQL> select * from nls_database_parameters;

PARAMETER                      VALUE
------------------------------ -------------------------------------------------
-------------------------------
NLS_LANGUAGE                   AMERICAN
NLS_TERRITORY                  AMERICA
NLS_CURRENCY                   $
NLS_ISO_CURRENCY               AMERICA
NLS_NUMERIC_CHARACTERS         .,
NLS_CHARACTERSET               ZHS16GBK
NLS_CALENDAR                   GREGORIAN
NLS_DATE_FORMAT                DD-MON-RR
NLS_DATE_LANGUAGE              AMERICAN
NLS_SORT                       BINARY
NLS_TIME_FORMAT                HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT           DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT             HH.MI.SSXFF AM TZR
NLS_TIMESTAMP_TZ_FORMAT        DD-MON-RR HH.MI.SSXFF AM TZR
NLS_DUAL_CURRENCY              $
NLS_COMP                       BINARY
NLS_LENGTH_SEMANTICS           BYTE
NLS_NCHAR_CONV_EXCP            FALSE
NLS_NCHAR_CHARACTERSET         AL16UTF16
NLS_RDBMS_VERSION              10.2.0.1.0

已选择20行?/span>

SQL> select lengthb('A') from dual;

LENGTHB('A')
------------
           1

已选择 1 行?/span>

SQL> select lengthb('?) from dual;

LENGTHB('?)
-------------
            2

已选择 1 行?br /> 可见我们新的数据库的是ZHS16GBK字符集,1个汉字占?个字?br /> 11 要启动旧数据库(因ؓ新旧数据库同名,而且oracle xe限制同时只能打开一个数据库Q?br /> SQL> shutdown immediate
数据库已l关闭?br /> 已经卸蝲数据库?br /> ORACLE 例程已经关闭?br /> SQL> startup
ORACLE 例程已经启动?/span>

Total System Global Area  285212672 bytes
Fixed Size                  1287016 bytes
Variable Size              96472216 bytes
Database Buffers          184549376 bytes
Redo Buffers                2904064 bytes
数据库装载完毕?br /> 数据库已l打开?/span>

----

如果以后要用spfile自动新徏数据?br /> SQL> create spfile from pfile='D:\oraclexe\app\oracle\product\10.2.0\server\config\scripts\test.ora';

文g已创建?/span>

SQL> shutdown immediate;
数据库已l关闭?br /> 已经卸蝲数据库?br /> ORACLE 例程已经关闭?br /> SQL> startup
ORACLE 例程已经启动?/span>

Total System Global Area 285212672 bytes
Fixed Size 1287016 bytes
Variable Size 92277912 bytes
Database Buffers 188743680 bytes
Redo Buffers 2904064 bytes
数据库装载完毕?br /> 数据库已l打开?br /> SQL> select lengthb('?) from dual;

LENGTHB('?)
-------------
2

已选择 1 行?/span>

q程dQ客L也需?0g
SQL> conn system/sys@//10.6.xx.xx:1521/XE
已连接?br /> SQL> conn sys/sys@//10.6.xx.xx:1521/XE as sysdba
已连接?/span>

[url]http://www.itpub.net/558697.html[/url]
的问题也得C解决

 

本文来自CSDN博客Q{载请标明出处Qhttp://blog.csdn.net/l1t/archive/2006/05/31/765125.aspx



久久不醉 2009-12-28 15:17 发表评论
]]>
Oracle pȝ表大?/title><link>http://www.aygfsteel.com/jiujiubuzui/archive/2009/12/22/306921.html</link><dc:creator>久久不醉</dc:creator><author>久久不醉</author><pubDate>Tue, 22 Dec 2009 07:56:00 GMT</pubDate><guid>http://www.aygfsteel.com/jiujiubuzui/archive/2009/12/22/306921.html</guid><wfw:comment>http://www.aygfsteel.com/jiujiubuzui/comments/306921.html</wfw:comment><comments>http://www.aygfsteel.com/jiujiubuzui/archive/2009/12/22/306921.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.aygfsteel.com/jiujiubuzui/comments/commentRss/306921.html</wfw:commentRss><trackback:ping>http://www.aygfsteel.com/jiujiubuzui/services/trackbacks/306921.html</trackback:ping><description><![CDATA[<p><span style="font-size: 14pt"><span style="font-size: 12pt"><span style="font-size: 10pt"><span style="font-size: 12pt"><span style="font-size: 10pt">        数据字典dictL属于Oracle用户sys的?br />   1、用P<br />    select username from dba_users;<br />   改口?br />    alter user spgroup identified by spgtest;<br />   2、表I间Q?br />    select * from dba_data_files;<br />    select * from dba_tablespaces;//表空?/span></span></span></span></span></p> <p><span style="font-size: 14pt"><span style="font-size: 12pt"><span style="font-size: 10pt"><span style="font-size: 12pt"><span style="font-size: 10pt">   select tablespace_name,sum(bytes), sum(blocks)<br />     from dba_free_space group by tablespace_name;//I闲表空?/span></span></span></span></span></p> <p><span style="font-size: 14pt"><span style="font-size: 12pt"><span style="font-size: 10pt"><span style="font-size: 12pt"><span style="font-size: 10pt">   select * from dba_data_files<br />     where tablespace_name='RBS';//表空间对应的数据文g</span></span></span></span></span></p> <p><span style="font-size: 14pt"><span style="font-size: 12pt"><span style="font-size: 10pt"><span style="font-size: 12pt"><span style="font-size: 10pt">   select * from dba_segments<br />     where tablespace_name='INDEXS';<br />   3、数据库对象Q?br />    select * from dba_objects;<br />    CLUSTER、DATABASE LINK、FUNCTION、INDEX、LIBRARY、PACKAGE、PACKAGE BODY?br />    PROCEDURE、SEQUENCE、SYNONYM、TABLE、TRIGGER、TYPE、UNDEFINED、VIEW?br />   4、表Q?br />    select * from dba_tables;<br />    analyze my_table compute statistics;->dba_tables??br />    select extent_id,bytes from dba_extents<br />    where segment_name='CUSTOMERS' and segment_type='TABLE'<br />    order by extent_id;//表用的extent的信息。segment_type='ROLLBACK'查看回滚D늚I间分配信息<br />    列信息:<br />     select distinct table_name<br />     from user_tab_columns<br />     where column_name='SO_TYPE_ID';<br />   5、烦引: <br />    select * from dba_indexes;//索引Q包括主键烦?br />    select * from dba_ind_columns;//索引?br />    select i.index_name,i.uniqueness,c.column_name<br />     from user_indexes i,user_ind_columns c<br />      where i.index_name=c.index_name<br />      and i.table_name ='ACC_NBR';//联接使用<br />   6、序列:<br />    select * from dba_sequences;<br />   7、视图:<br />    select * from dba_views;<br />    select * from all_views;<br />   text 可用于查询视囄成的脚本<br />   8、聚:<br />    select * from dba_clusters;<br />   9、快照:<br />    select * from dba_snapshots;<br />   快照、分区应存在相应的表I间?br />   10、同义词Q?br />    select * from dba_synonyms<br />     where table_owner='SPGROUP';<br />     //if owner is PUBLIC,then the synonyms is a public synonym.<br />      if owner is one of users,then the synonyms is a private synonym.<br />   11、数据库链:<br />    select * from dba_db_links;<br />   在spbase下徏数据库链<br />    create database link dbl_spnew<br />    connect to spnew identified by spnew using 'jhhx';<br />    insert into acc_nbr@dbl_spnew<br />    select * from acc_nbr where nxx_nbr='237' and line_nbr='8888';<br />   12、触发器Q?br />    select * from dba_trigers;<br />   存储q程Q函Cdba_objects查找?br />   其文本:select text from user_source where name='BOOK_SP_EXAMPLE';<br />   建立出错Qselect * from user_errors;<br />   oracleL存储过E,函数{Y件放在SYSTEM表空间?br />   13、约束:<br />   Q?Q约束是和表兌的,可在create table或alter table table_name add/drop/modify来徏立、修攏V删除约束?br />   可以临时止U束Q如Q?br />    alter table book_example<br />    disable constraint book_example_1;<br />    alter table book_example<br />    enable constraint book_example_1;<br />   Q?Q主键和外键被称U束Q而not null和unique之类的约束被UCؓ列约束。通常主键和外键作ؓ单独的命名约束放在字D列表下面,而列U束可放在列定义的同一行,q样更具有可L?br />   Q?Q列U束可从表定义看出,即describe;表约束即主键和外键,可从dba_constraints和dba_cons_columns 查?br />    select * from user_constraints<br />    where table_name='BOOK_EXAMPLE';<br />    select owner,CONSTRAINT_NAME,TABLE_NAME<br />     from user_constraints<br />     where constraint_type='R'<br />     order by table_name;<br />   Q?Q定义约束可以无名(pȝ自动生成U束名)和自己定义约束名Q特别是主键、外键)<br />   如:create table book_example<br />     (identifier number not null);<br />     create table book_example<br />     (identifier number constranit book_example_1 not null);<br />   14、回滚段Q?br />   在所有的修改l果存入盘前,回滚D中保持恢复该事务所需的全部信息,必须以数据库发生的事务来相应定其大(DML语句才可回滚Qcreate,drop,truncate{DDL不能回滚Q?br />   回滚D|?q发事务/4Q但不能过50Q每个回滚D大够处理一个完整的事务Q?br />    create rollback segment r05<br />    tablespace rbs;<br />    create rollback segment rbs_cvt<br />    tablespace rbs<br />    storage(initial 1M next 500k);<br />   使回滚段在线<br />    alter rollback segment r04 online;<br />   用dba_extents,v$rollback_segs监测回滚D늚大小和动态增ѝ?br />   回滚D늚区间信息<br />    select * from dba_extents<br />    where segment_type='ROLLBACK' and segment_name='RB1';<br />   回滚D늚D信?其中bytes昄目前回滚D늚字节?br />    select * from dba_segments<br />     where segment_type='ROLLBACK' and segment_name='RB1';<br />   Z物指定回归段<br />    set transaction use rollback segment rbs_cvt<br />   针对bytes可以使用回滚D回~?br />    alter rollback segment rbs_cvt shrink;<br />    select bytes,extents,max_extents from dba_segments<br />     where segment_type='ROLLBACK' and segment_name='RBS_CVT';<br />   回滚D늚当前状态信息:<br />    select * from dba_rollback_segs<br />     where segment_name='RB1';<br />   比多回滚D늊态statusQ回滚段所属实例instance_num<br />   查优化值optimal<br />    select n.name,s.optsize<br />     from v$rollname n,v$rollstat s<br />      where n.usn=s.usn;<br />   回滚D中的数?br />    set transaction use rollback segment rb1;/*回滚D名*/<br />    select n.name,s.writes<br />     from v$rollname n,v$rollstat s<br />      where n.usn=s.usn;<br />   当事务处理完毕,再次查询$rollstatQ比较writes(回滚D|目字节数)差|可确定事务的大小?br />   查询回滚D中的事?br />    column rr heading 'RB Segment' format a18<br />    column us heading 'Username' format a15<br />    column os heading 'Os User' format a10<br />    column te heading 'Terminal' format a10<br />    select r.name rr,nvl(s.username,'no transaction') us,s.osuser os,s.terminal te<br />     from v$lock l,v$session s,v$rollname r<br />      where l.sid=s.sid(+)<br />      and trunc(l.id1/65536)=R.USN<br />      and l.type='TX'<br />      and l.lmode=6<br />    order by r.name;<br />   15、作?br />   查询作业信息<br />    select job,broken,next_date,interval,what from user_jobs;<br />    select job,broken,next_date,interval,what from dba_jobs;<br />   查询正在q行的作?br />    select * from dba_jobs_running;<br />   使用包exec dbms_job.submit(:v_num,'a;',sysdate,'sysdate + (10/(24*60*60))')加入作业。间?0U钟<br /> exec dbms_job.submit(:v_num,'a;',sysdate,'sysdate + (11/(24*60))')加入作业。间?1分钟使用包exec dbms_job.remove(21)删除21号作业?/span></span></span></span></span></p><img src ="http://www.aygfsteel.com/jiujiubuzui/aggbug/306921.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.aygfsteel.com/jiujiubuzui/" target="_blank">久久不醉</a> 2009-12-22 15:56 <a href="http://www.aygfsteel.com/jiujiubuzui/archive/2009/12/22/306921.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss> <footer> <div class="friendship-link"> <a href="http://www.aygfsteel.com/" title="狠狠久久亚洲欧美专区_中文字幕亚洲综合久久202_国产精品亚洲第五区在线_日本免费网站视频">狠狠久久亚洲欧美专区_中文字幕亚洲综合久久202_国产精品亚洲第五区在线_日本免费网站视频</a> </div> </footer> վ֩ģ壺 <a href="http://" target="_blank">ͺ</a>| <a href="http://" target="_blank">ɽ</a>| <a href="http://" target="_blank">̫</a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank">ղ</a>| <a href="http://" target="_blank">Ȫ</a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank">ɽ</a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank">ʯɽ</a>| <a href="http://" target="_blank">۲</a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank">Ƽ</a>| <a href="http://" target="_blank">Ȩ</a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank">Ӧ</a>| <a href="http://" target="_blank">β</a>| <a href="http://" target="_blank">ͨɽ</a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank">潭</a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank">ʯ</a>| <a href="http://" target="_blank">Ȫ</a>| <a href="http://" target="_blank">Ͻ</a>| <a href="http://" target="_blank">Ȫ</a>| <a href="http://" target="_blank"></a>| <a href="http://" target="_blank">½</a>| <a href="http://" target="_blank"></a>| <script> (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })(); </script> </body>