锘??xml version="1.0" encoding="utf-8" standalone="yes"?>久久精品国产亚洲av水果派 ,中中文字幕亚洲无线码,亚洲av成人无码久久精品http://www.tkk7.com/ywj-316/category/43994.htmlzh-cnTue, 20 Apr 2010 19:25:29 GMTTue, 20 Apr 2010 19:25:29 GMT60C3P0榪炴帴姹犺緇嗛厤緗?/title><link>http://www.tkk7.com/ywj-316/archive/2010/04/20/318804.html</link><dc:creator>junly</dc:creator><author>junly</author><pubDate>Tue, 20 Apr 2010 01:20:00 GMT</pubDate><guid>http://www.tkk7.com/ywj-316/archive/2010/04/20/318804.html</guid><wfw:comment>http://www.tkk7.com/ywj-316/comments/318804.html</wfw:comment><comments>http://www.tkk7.com/ywj-316/archive/2010/04/20/318804.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.tkk7.com/ywj-316/comments/commentRss/318804.html</wfw:commentRss><trackback:ping>http://www.tkk7.com/ywj-316/services/trackbacks/318804.html</trackback:ping><description><![CDATA[     鎽樿: <c3p0-config>    <default-config>  <!--褰撹繛鎺ユ睜涓殑榪炴帴鑰楀敖鐨勬椂鍊檆3p0涓嬈″悓鏃惰幏鍙栫殑榪炴帴鏁般侱efault: 3 -->  <property name="acquireIncrement">3</property&g...  <a href='http://www.tkk7.com/ywj-316/archive/2010/04/20/318804.html'>闃呰鍏ㄦ枃</a><img src ="http://www.tkk7.com/ywj-316/aggbug/318804.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.tkk7.com/ywj-316/" target="_blank">junly</a> 2010-04-20 09:20 <a href="http://www.tkk7.com/ywj-316/archive/2010/04/20/318804.html#Feedback" target="_blank" style="text-decoration:none;">鍙戣〃璇勮</a></div>]]></description></item><item><title>JNDI鍘熺悊http://www.tkk7.com/ywj-316/archive/2010/02/23/313685.htmljunlyjunlyTue, 23 Feb 2010 02:36:00 GMThttp://www.tkk7.com/ywj-316/archive/2010/02/23/313685.htmlhttp://www.tkk7.com/ywj-316/comments/313685.htmlhttp://www.tkk7.com/ywj-316/archive/2010/02/23/313685.html#Feedback0http://www.tkk7.com/ywj-316/comments/commentRss/313685.htmlhttp://www.tkk7.com/ywj-316/services/trackbacks/313685.html浠涔堟槸JNDI錛熶負(fù)浠涔堜嬌鐢↗NDI錛?/strong>

JNDI鏄疛ava 鍛藉悕涓庣洰褰曟帴鍙o紙Java Naming and Directory Interface錛?/p>

瑕佷簡(jiǎn)瑙NDI鐨勪綔鐢紝鎴戜滑鍙互浠?#8220;濡傛灉涓嶇敤JNDI鎴戜滑鎬庢牱鍋氾紵鐢ㄤ簡(jiǎn)JNDI鍚庢垜浠張灝嗘庢牱鍋氾紵”榪欎釜闂鏉ユ帰璁ㄣ?/p>

娌℃湁JNDI鐨勫仛娉曪細(xì)
紼嬪簭鍛樺紑鍙戞椂錛岀煡閬撹寮鍙戣闂甅ySQL鏁版嵁搴撶殑搴旂敤錛屼簬鏄皢涓涓 MySQL JDBC 椹卞姩紼嬪簭綾葷殑寮曠敤榪涜浜?jiǎn)缂栫爜锛岒q墮氳繃浣跨敤閫傚綋鐨?JDBC URL 榪炴帴鍒版暟鎹簱銆?br /> 灝卞儚浠ヤ笅浠g爜榪欐牱錛?/p>

Connection conn=null;
try {
   Class.forName("com.mysql.jdbc.Driver",true, Thread.currentThread().getContextClassLoader());        conn=DriverManager.getConnection("jdbc:mysql://MyDBServer?user=qingfeng&password=mingyue");  /* 浣跨敤conn騫惰繘琛孲QL鎿嶄綔 */     conn.close();
} catch(Exception e) {
   e.printStackTrace();
} finally {
   if(conn!=null) {
    try {       conn.close();   
    } catch(SQLException e) {
    }
}}
榪欐槸浼犵粺鐨勫仛娉曪紝榪欑鍋氭硶涓鑸湪灝忚妯$殑寮鍙戣繃紼嬩腑涓嶄細(xì)浜х敓闂錛屽彧瑕佺▼搴忓憳鐔熸?zhèn)塉ava璇█銆佷簡(jiǎn)瑙DBC鎶鏈拰MySQL錛屽彲浠ュ緢蹇紑鍙戝嚭鐩稿簲鐨勫簲鐢ㄧ▼搴忋?/p>

娌℃湁JNDI鐨勫仛娉曞瓨鍦ㄧ殑闂錛?br /> 1銆佹暟鎹簱鏈嶅姟鍣ㄥ悕縐癕yDBServer 銆佺敤鎴峰悕鍜屽彛浠ら兘鍙兘闇瑕佹敼鍙橈紝鐢辨寮曞彂JDBC URL闇瑕佷慨鏀癸紱
2銆佹暟鎹簱鍙兘鏀圭敤鍒殑浜у搧錛屽鏀圭敤DB2鎴栬匫racle錛屽紩鍙慗DBC椹卞姩紼嬪簭鍖呭拰綾誨悕闇瑕佷慨鏀癸紱
3銆侀殢鐫瀹為檯浣跨敤緇堢鐨勫鍔狅紝鍘熼厤緗殑榪炴帴姹犲弬鏁板彲鑳介渶瑕佽皟鏁達(dá)紱
4銆?.....

瑙e喅鍔炴硶錛?br /> 紼嬪簭鍛樺簲璇ヤ笉闇瑕佸叧蹇?#8220;鍏蜂綋鐨勬暟鎹簱鍚庡彴鏄粈涔堬紵JDBC椹卞姩紼嬪簭鏄粈涔堬紵JDBC URL鏍煎紡鏄粈涔堬紵璁塊棶鏁版嵁搴撶殑鐢ㄦ埛鍚嶅拰鍙d護(hù)鏄粈涔堬紵”絳夌瓑榪欎簺闂錛岀▼搴忓憳緙栧啓鐨勭▼搴忓簲璇ユ病鏈夊 JDBC 椹卞姩紼嬪簭鐨勫紩鐢紝娌℃湁鏈嶅姟鍣ㄥ悕縐幫紝娌℃湁鐢ㄦ埛鍚嶇О鎴栧彛浠?鈥斺?鐢氳嚦娌℃湁鏁版嵁搴撴睜鎴栬繛鎺ョ鐞嗐傝屾槸鎶婅繖浜涢棶棰樹氦緇橨2EE瀹瑰櫒鏉ラ厤緗拰綆$悊錛岀▼搴忓憳鍙渶瑕佸榪欎簺閰嶇疆鍜岀鐞嗚繘琛屽紩鐢ㄥ嵆鍙?/p>

鐢辨錛屽氨鏈変簡(jiǎn)JNDI銆?/p>

鐢ㄤ簡(jiǎn)JNDI涔嬪悗鐨勫仛娉曪細(xì)
棣栧厛錛屽湪鍦↗2EE瀹瑰櫒涓厤緗甁NDI鍙傛暟錛屽畾涔変竴涓暟鎹簮錛屼篃灝辨槸JDBC寮曠敤鍙傛暟錛岀粰榪欎釜鏁版嵁婧愯緗竴涓悕縐幫紱鐒跺悗錛屽湪紼嬪簭涓紝閫氳繃鏁版嵁婧愬悕縐板紩鐢ㄦ暟鎹簮浠庤岃闂悗鍙版暟鎹簱銆?br /> 鍏蜂綋鎿嶄綔濡備笅錛堜互JBoss涓轟緥錛夛細(xì)
1銆侀厤緗暟鎹簮
鍦↗Boss鐨?D:\jboss420GA\docs\examples\jca 鏂囦歡澶逛笅闈紝鏈夊緢澶氫笉鍚屾暟鎹簱寮曠敤鐨勬暟鎹簮瀹氫箟妯℃澘銆傚皢鍏朵腑鐨?mysql-ds.xml 鏂囦歡Copy鍒頒綘浣跨敤鐨勬湇鍔″櫒涓嬶紝濡?D:\jboss420GA\server\default\deploy銆?br /> 淇敼 mysql-ds.xml 鏂囦歡鐨勫唴瀹癸紝浣夸箣鑳介氳繃JDBC姝g‘璁塊棶浣犵殑MySQL鏁版嵁搴擄紝濡備笅錛?br /> <?xml version="1.0" encoding="UTF-8"?>
<datasources>
<local-tx-datasource>
    <jndi-name>MySqlDS</jndi-name>
    <connection-url>jdbc:mysql://localhost:3306/lw</connection-url>
    <driver-class>com.mysql.jdbc.Driver</driver-class>
    <user-name>root</user-name>
    <password>rootpassword</password>
<exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLExceptionSorter</exception-sorter-class-name>
    <metadata>
       <type-mapping>mySQL</type-mapping>
    </metadata>
</local-tx-datasource>
</datasources>

榪欓噷錛屽畾涔変簡(jiǎn)涓涓悕涓篗ySqlDS鐨勬暟鎹簮錛屽叾鍙傛暟鍖呮嫭JDBC鐨刄RL錛岄┍鍔ㄧ被鍚嶏紝鐢ㄦ埛鍚嶅強(qiáng)瀵嗙爜絳夈?/p>

2銆佸湪紼嬪簭涓紩鐢ㄦ暟鎹簮錛?/p>

Connection conn=null;
try { 
Context ctx=new InitialContext();
Object datasourceRef=ctx.lookup("java:MySqlDS"); //寮曠敤鏁版嵁婧?nbsp;
DataSource ds=(Datasource)datasourceRef;  conn=ds.getConnection();  /* 浣跨敤conn榪涜鏁版嵁搴揝QL鎿嶄綔 */
...... 
c.close();
} catch(Exception e) { 
e.printStackTrace();
} finally {  if(conn!=null) {   
 try {    
 conn.close();   
 } catch(SQLException e) { }  }}
鐩存帴浣跨敤JDBC鎴栬呴氳繃JNDI寮曠敤鏁版嵁婧愮殑緙栫▼浠g爜閲忕浉宸棤鍑狅紝浣嗘槸鐜板湪鐨勭▼搴忓彲浠ヤ笉鐢ㄥ叧蹇?jī)鍏蜂綋JDBC鍙傛暟浜?jiǎn)銆?br /> 鍦ㄧ郴緇熼儴緗插悗錛屽鏋滄暟鎹簱鐨勭浉鍏沖弬鏁板彉鏇達(dá)紝鍙渶瑕侀噸鏂伴厤緗?mysql-ds.xml 淇敼鍏朵腑鐨凧DBC鍙傛暟錛屽彧瑕佷繚璇佹暟鎹簮鐨勫悕縐頒笉鍙橈紝閭d箞紼嬪簭婧愪唬鐮佸氨鏃犻渶淇敼銆?/p>

鐢辨鍙錛孞NDI閬垮厤浜?jiǎn)绋嬪簭涓庢暟鎹簱涔嬮棿鐨勭揣鑰﹀悎錛屼嬌搴旂敤鏇村姞鏄撲簬閰嶇疆銆佹槗浜庨儴緗層?/p>

鎵浠ワ紝鍦↗2EE瑙勮寖涓紝J2EE 涓殑璧勬簮騫朵笉灞闄愪簬 JDBC 鏁版嵁婧愩傚紩鐢ㄧ殑綾誨瀷鏈夊緢澶氾紝鍏朵腑鍖呮嫭璧勬簮寮曠敤錛堝凡緇忚璁鴻繃錛夈佺幆澧冨疄浣撳拰 EJB 寮曠敤銆傜壒鍒槸 EJB 寮曠敤錛屽畠鏆撮湶浜?JNDI 鍦?J2EE 涓殑鍙﹀涓欏瑰叧閿鑹詫細(xì)鏌ユ壘鍏朵粬搴旂敤紼嬪簭緇勪歡銆?/p>

 

JNDI鍘熺悊

sun鍙槸鎻愪緵浜?jiǎn)JNDI鐨勬帴鍙?鍗寵鑼?,IBM, Novell, Sun 鍜?WebLogic 鍜孞BOSS宸茬粡涓?JNDI 鎻愪緵浜?jiǎn)鏈嶅姟鎻愪緵绋嬪?

鍦↗NDI涓紝鍦ㄧ洰褰曠粨鏋勪腑鐨勬瘡涓涓粨鐐圭О涓篶ontext銆傛瘡涓涓狫NDI鍚嶅瓧閮芥槸鐩稿浜巆ontext鐨勩傝繖閲屾病鏈夌粷瀵瑰悕瀛楃殑姒傚康瀛樺湪銆傚涓涓簲鐢ㄦ潵璇達(dá)紝瀹冨彲浠ラ氳繃浣跨敤 InitialContext 綾繪潵寰楀埌鍏剁涓涓猚ontext: 

    Context ctx = new InitialContext();

    ctx.bind("name", Object);

    ctx.lookup("name");

Context:涓婁笅鏂?鎴戠殑鐞嗚В鏄浉褰撲笌鏂囦歡緋葷粺鐨勪腑鐨勭洰褰?JNDI鐨凬aming Service鏄彲浠ョ敤鎿嶄綔緋葷粺鐨勬枃浠剁郴緇熺殑,鍝堝搱).

entry/object:涓涓妭鐐?鐩稿綋涓庢枃浠剁郴緇熶腑鐨勭洰褰曟垨鏂囦歡.

filter:鏌ヨ/榪囨護(hù)鏉′歡鏄竴涓瓧絎︿覆琛ㄨ揪寮忓:(&(objectClass=top)(cn=*))鏌ヨ鍑簅bjectClass灞炴т負(fù)top,cn灞炴т負(fù)鎵鏈夋儏鍐電殑entry.

Attribute:entry/object鐨勫睘鎬у彲浠ョ悊瑙f垚JAVA瀵硅薄鐨勫睘鎬?涓嶅悓鐨勬槸榪欎釜灞炴у彲浠ュ嬈¤祴鍊?

A.灝嗘帴鍙e垎涓篊ontext 鍜?DirContext  

   JNDI鏈変袱涓牳蹇?jī)鎺ュ彛Context鍜孌irContext錛孋ontext涓寘鍚?浜?jiǎn)鍩烘湰鐨勫悕瀛楁搷浣滃Q岃孌irContext鍒欏皢榪欎簺鎿嶄綔鎵╁睍鍒扮洰褰曟湇鍔°侱irContext 瀵笴ontext榪涜浜?jiǎn)鎵╁睍锛屾彁渚涗簡(jiǎn)鍩烘湰鐨勭洰褰曟湇鍔℃搷浣滃Q?瀵瑰悕瀛楀璞″睘鎬х殑緇存姢銆佸熀浜庡睘鎬х殑鍚嶅瓧鏌ユ壘絳夌瓑銆?nbsp; 

B.涓婁笅鏂囧垪琛ㄧ殑澶氱鏂規(guī)硶  

   涓鑸潵璇存湁涓ょ榪涜涓婁笅鏂囧垪琛ㄧ殑搴旂敤錛氫笂涓嬫枃嫻忚搴旂敤鍜屽涓婁笅鏂囦腑鐨勫璞¤繘琛屽疄闄呮搷浣滅殑搴旂敤銆?nbsp; 

   涓婁笅鏂囨祻瑙堝簲鐢ㄤ竴鑸彧闇瑕佹樉紺轟笂涓嬫枃涓寘鍚唴瀹圭殑鍚嶅瓧錛屾垨鑰呭啀鑾峰彇涓浜涜濡傚璞$殑綾誨瀷涔嬬被鐨勪俊鎭傝繖縐嶇被鍨嬬殑搴旂敤涓鑸兘鏄氦浜掑紡鐨勶紝鍙互鍏佽鐢ㄦ埛鍦ㄥ垪涓劇殑涓婁笅鏂囧垪琛ㄤ腑閫夋嫨涓浜涜繘琛岃繘涓姝ョ殑鏄劇ず銆?nbsp; 

   鍙﹀鏈変竴浜涘簲鐢ㄩ渶瑕佸涓婁笅鏂囦腑鐨勫璞¤繘琛屽疄闄呯殑鎿嶄綔錛屾瘮濡傦紝涓涓浠界▼搴忛渶瑕佸鐩綍涓墍鏈夋枃浠剁殑鐘舵佽繘琛屾搷浣滐紝鎴栬呮煇鎵撳嵃鏈虹鐞嗗憳鍙兘闇瑕佸澶фゼ涓殑鎵鏈夋墦鍗版満榪涜澶嶄綅銆備負(fù)浜?jiǎn)杩涜杩欐狅L(fēng)殑鎿嶄綔錛岀▼搴忛渶瑕佽幏鍙栦笂涓嬫枃涓殑瀹為檯瀵硅薄銆?nbsp; 

   瀵逛簬榪欐牱涓ょ綾誨瀷鐨勫簲鐢紝Context鎺ュ彛鎻愪緵浜?jiǎn)涓たU嶄笂涓嬫枃鍒楄〃鏂規(guī)硶list()鍜?listBindings()銆傚叾涓璴ist()鍙繑鍥炰竴緋誨垪鍚嶅瓧/綾繪槧灝勶紝鑰宭istBindings() 鍒欒繑鍥炲悕瀛椼佺被鍜屽璞℃湰韜傛樉鐒?list()鐢ㄤ簬涓婁笅鏂囨祻瑙堝簲鐢ㄨ宭istBindings()鐢ㄤ簬閭d簺闇瑕佸瀵硅薄榪涜瀹為檯鎿嶄綔鐨勫簲鐢ㄣ?nbsp; 
渚?
=================灝嗕互涓嬩唬鐮佹娣誨姞鍒皊erver.xml涓殑<Host>涓?===========
<!-- configure DataSource. Add the following code into server.xml -->

<Context path="/bookstore" docBase="bookstore" debug="0"
reloadable="true" >

<!-- 鏁版嵁婧愬悕縐?-->
<Resource name="jdbc/BookDB"
               auth="Container"
               type="javax.sql.DataSource" />

<ResourceParams name="jdbc/BookDB">
    <parameter>
      <name>factory</name>
      <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
    </parameter>

    <!-- Maximum number of dB connections in pool. Make sure you
         configure your mysqld max_connections large enough to handle
         all of your db connections. Set to 0 for no limit.
         -->
<!-- 媧誨姩鐘舵佹渶澶ц繛鎺ユ暟 -->
    <parameter>
      <name>maxActive</name>
      <value>100</value>
    </parameter>

    <!-- Maximum number of idle dB connections to retain in pool.
         Set to 0 for no limit.
         -->
<!-- 絀洪棽鐘舵佹暟鎹簱榪炴帴鏈澶ф暟 -->
    <parameter>
      <name>maxIdle</name>
      <value>30</value>
    </parameter>

    <!-- Maximum time to wait for a dB connection to become available
         in ms, in this example 10 seconds. An Exception is thrown if
         this timeout is exceeded. Set to -1 to wait indefinitely.
        Maximum time to wait for a dB connection to become available
         in ms, in this example 10 seconds. An Exception is thrown if
         this timeout is exceeded. Set to -1 to wait indefinitely.
         -->
<!-- 鏁版嵁搴撳浜庣┖闂茬姸鎬佺殑鏈闀挎椂闂?-->
    <parameter>
      <name>maxWait</name>
      <value>10000</value>
    </parameter>

    <!-- MySQL dB username and password for dB connections -->
<!-- 鎸囧畾榪炴帴鏁版嵁搴撶殑鐢ㄦ埛鍚嶅強(qiáng)瀵嗙爜 -->
    <parameter>
     <name>username</name>
     <value>dbuser</value>
    </parameter>
    <parameter>
     <name>password</name>
     <value>1234</value>
    </parameter>

    <!-- Class name for mm.mysql JDBC driver -->
<!-- 鎸囧畾JDBC椹卞姩 -->
    <parameter>
       <name>driverClassName</name>
       <value>com.mysql.jdbc.Driver</value>
    </parameter>

    <!-- The JDBC connection url for connecting to your MySQL dB.
         The autoReconnect=true argument to the url makes sure that the
         mm.mysql JDBC Driver will automatically reconnect if mysqld closed the
         connection. mysqld by default closes idle connections after 8 hours.
         -->
<!-- 鎸囧畾榪炴帴鏁版嵁搴撶殑URL -->
    <parameter>
      <name>url</name>
      <value>jdbc:mysql://localhost:3306/BookDB?autoReconnect=true</value>
    </parameter>
</ResourceParams>

</Context> 
榪愯鏈哄埗錛?
1銆?棣栧厛紼嬪簭浠g爜鑾峰彇鍒濆鍖栫殑 JNDI 鐜騫朵笖璋冪敤 Context.lookup() 鏂規(guī)硶浠?JNDI 鏈嶅姟鎻愪緵鑰呴偅閲岃幏涓涓?DataSource 瀵硅薄

2銆?涓棿灞?JNDI 鏈嶅姟鎻愪緵鑰呰繑鍥炰竴涓?DataSource 瀵硅薄緇欏綋鍓嶇殑 Java 搴旂敤紼嬪簭榪欎釜 DataSource 瀵硅薄浠h〃浜?jiǎn)涓棿灞傛湇鍔′笂鐜板瓨鐨劸~撳啿鏁版嵁婧?

3銆?搴旂敤紼嬪簭璋冪敤 DataSource 瀵硅薄鐨?getConnection() 鏂規(guī)硶

4銆?褰?DataSource 瀵硅薄鐨?getConnection() 鏂規(guī)硶琚皟鐢ㄦ椂錛屼腑闂村眰鏈嶅姟鍣ㄥ皢鏌ヨ鏁版嵁搴?榪炴帴緙撳啿姹犱腑鏈夋病鏈?PooledConnection 鎺ュ彛鐨勫疄渚嬪璞°傝繖涓?PooledConnection 瀵硅薄灝嗚鐢ㄤ簬涓庢暟鎹簱寤虹珛鐗╃悊涓婄殑鏁版嵁搴撹繛鎺?

5銆?濡傛灉鍦ㄧ紦鍐叉睜涓懡涓簡(jiǎn)涓涓?PooledCoonection 瀵硅薄閭d箞榪炴帴緙撳啿姹犲皢綆鍗曞湴鏇?鏂板唴閮ㄧ殑緙撳啿榪炴帴闃熷垪騫跺皢璇?PooledConnection 瀵硅薄榪斿洖銆傚鏋滃湪緙撳啿姹犲唴娌?鏈夋壘鍒扮幇鎴愮殑 PooledConnection 瀵硅薄錛岄偅涔?ConnectionPoolDataSource 鎺ュ彛灝嗕細(xì)琚?鐢ㄦ潵浜х敓涓涓柊鐨?PooledConnection 瀵硅薄騫跺皢瀹冭繑鍥炰互渚垮簲鐢ㄧ▼搴忎嬌鐢?

6銆?涓棿灞傛湇鍔″櫒璋冪敤 PooledConnection 瀵硅薄鐨?getConnection() 鏂規(guī)硶浠ヤ究榪旇繕涓涓?java.sql.Connection 瀵硅薄緇欏綋鍓嶇殑 Java 搴旂敤紼嬪簭

7銆?褰撲腑闂村眰鏈嶅姟鍣ㄨ皟鐢?PooledConnection 瀵硅薄鐨?getConnection() 鏂規(guī)硶鏃訛紝 JDBC 鏁版嵁 搴撻┍鍔ㄧ▼搴忓皢浼?xì)鍒涘晦Z竴涓?Connection 瀵硅薄騫朵笖鎶婂畠榪斿洖涓棿灞傛湇鍔″櫒

8銆?涓棿灞傛湇鍔″櫒灝?Connection 瀵硅薄榪斿洖緇欏簲鐢ㄧ▼搴?Java 搴旂敤紼嬪簭錛屽彲浠ヨ涓鴻繖涓?Connection 瀵硅薄鏄竴涓櫘閫氱殑 JDBC Connection 瀵硅薄浣跨敤瀹冨彲浠ュ拰鏁版嵁搴撳緩绔嬨備簨 瀹炰笂鐨勮繛鎺ヤ笌鏁版嵁搴撳紩鎿庝駭鐢熶氦浜掓搷浣?銆?/p>

9銆?褰撳簲鐢ㄧ▼搴忎笉闇瑕佷嬌鐢?Connection 瀵硅薄鏃訛紝鍙互璋冪敤 Connection 鎺ュ彛鐨?close() 鏂?娉曘傝娉ㄦ剰榪欑鎯呭喌涓?close() 鏂規(guī)硶騫舵病鏈夊叧闂簨瀹炰笂鐨勬暟鎹簱榪炴帴錛屼粎浠呮槸閲?鏀句簡(jiǎn)琚簲鐢ㄧ▼搴忓崰鐢ㄧ殑鏁版嵁搴撹繛鎺ワ紝騫跺皢瀹冭繕緇欐暟鎹簱榪炴帴緙撳啿姹狅紝鏁版嵁搴撹繛鎺?緙撳啿姹犱細(xì)鑷姩灝嗚繖涓暟鎹簱榪炴帴浜ょ粰璇鋒眰闃熷垪涓笅涓涓殑搴旂敤紼嬪簭浣跨敤銆?/p>

junly 2010-02-23 10:36 鍙戣〃璇勮
]]>
JDBChttp://www.tkk7.com/ywj-316/archive/2010/02/23/313683.htmljunlyjunlyTue, 23 Feb 2010 02:33:00 GMThttp://www.tkk7.com/ywj-316/archive/2010/02/23/313683.htmlhttp://www.tkk7.com/ywj-316/comments/313683.htmlhttp://www.tkk7.com/ywj-316/archive/2010/02/23/313683.html#Feedback0http://www.tkk7.com/ywj-316/comments/commentRss/313683.htmlhttp://www.tkk7.com/ywj-316/services/trackbacks/313683.htmlJDBC-ODBC妗ヨ繛鎺ユ暟鎹簱

涓嶈凍錛氶渶瑕佸湪瀹㈡埛绔畨瑁匫DBC椹卞姩紼嬪簭,ODBC椹卞姩紼嬪簭榪橀渶瑕佸叿鏈夊鎴風(fēng)鐨勬帶鍒舵潈闄愩?
鏂規(guī)硶錛?br /> 1.鍒涘緩鏁版嵁婧?
2.瑁呰澆椹卞姩騫朵笌DBMS寤虹珛榪炴帴
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");     
Connection con=DriverManager.getConnectio("jdbc:odbc:jia","sa","123");
3.鏌ヨ   
Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);
ResultSet rs = stmt.executeQuery(sql);   
4.鏇存柊   
Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);         
if(stmt.executeUpdate(sql)<=0){return false;}   
else{return true;}      
5.璇誨彇鏁版嵁
Statement 鎺ュ彛鎻愪緵浜?縐嶆墽琛孲QL璇彞鐨勬柟娉曪細(xì)
qexecuteQuery()
qexecuteUpdate()
qexecute()
6.tTransaction     
Connection con=DriverManager.getConnectio("jdbc:odbc:jia","sa","123");
con.setAutoCommit(false);//鍏抽棴鑷姩鎻愪氦妯″紡
Statement stmt = con.createStatement();   
stmt.qexecute(sql);   
stmt.qexecute(sql);   
stmt.qexecute(sql);     
con.commit();           //鎻愪氦 
con.setAutoCommit(true);//寮鍚嚜鍔ㄦ彁浜ゆā寮?br /> con.rollback();         //鍥炴粴
7.鍏抽棴榪炴帴瀵硅薄
con.close();
con.isClosed();

JDBC榪炴帴鏁版嵁搴?br />
鏂規(guī)硶:
1.Oracle8/8i/9i鏁版嵁搴擄紙thin妯″紡錛?
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
String url="jdbc:oracle:thin:@localhost:1521:orcl"; //orcl涓烘暟鎹簱SID
String user="test";
String password="test";
Connection conn= DriverManager.getConnection(url,user,password); 
2.DB2鏁版嵁搴?
Class.forName("com.ibm.db2.jdbc.app.DB2Driver ").newInstance();
String url="jdbc:db2://localhost:5000/sample"; //sample涓轟綘鐨勬暟鎹簱鍚?
String user="admin";
String password="";
Connection conn= DriverManager.getConnection(url,user,password); 
3.Sql Server7.0/2000鏁版嵁搴?
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance();
String url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb"; //mydb涓烘暟鎹簱
String user="sa";
String password="";
Connection conn= DriverManager.getConnection(url,user,password); 
4.Sybase鏁版嵁搴?
Class.forName("com.sybase.jdbc.SybDriver").newInstance();
String url =" jdbc:sybase:Tds:localhost:5007/myDB";//myDB涓轟綘鐨勬暟鎹簱鍚?
Properties sysProps = System.getProperties();
SysProps.put("user","userid");
SysProps.put("password","user_password");
Connection conn= DriverManager.getConnection(url, SysProps); 
5.Informix鏁版嵁搴?
Class.forName("com.informix.jdbc.IfxDriver").newInstance();
String url = "jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver;
user=testuser;password=testpassword"; //myDB涓烘暟鎹簱鍚?
Connection conn= DriverManager.getConnection(url); 
6.MySQL鏁版嵁搴?
Class.forName("org.gjt.mm.mysql.Driver").newInstance();
String url ="jdbc:mysql://localhost/myDB?user=soft&password=soft1234&useUnicode=true&characterEncoding=8859_1" //myDB涓烘暟鎹簱鍚?
Connection conn= DriverManager.getConnection(url); 
7.PostgreSQL鏁版嵁搴?
Class.forName("org.postgresql.Driver").newInstance();
String url ="jdbc:postgresql://localhost/myDB" //myDB涓烘暟鎹簱鍚?
String user="myuser";
String password="mypassword";
Connection conn= DriverManager.getConnection(url,user,password); 
8.access鏁版嵁搴撶洿榪炵敤ODBC鐨?br /> Class.forName("sun.jdbc.odbc.JdbcOdbcDriver") ;
String url="jdbc:odbc:Driver={MicroSoft Access Driver (*.mdb)};DBQ="+application.getRealPath("/Data/ReportDemo.mdb");
Connection conn = DriverManager.getConnection(url,"","");
Statement stmtNew=conn.createStatement() ;



junly 2010-02-23 10:33 鍙戣〃璇勮
]]>
JNDI榪炴帴姹?/title><link>http://www.tkk7.com/ywj-316/archive/2009/11/29/304131.html</link><dc:creator>junly</dc:creator><author>junly</author><pubDate>Sun, 29 Nov 2009 13:19:00 GMT</pubDate><guid>http://www.tkk7.com/ywj-316/archive/2009/11/29/304131.html</guid><wfw:comment>http://www.tkk7.com/ywj-316/comments/304131.html</wfw:comment><comments>http://www.tkk7.com/ywj-316/archive/2009/11/29/304131.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.tkk7.com/ywj-316/comments/commentRss/304131.html</wfw:commentRss><trackback:ping>http://www.tkk7.com/ywj-316/services/trackbacks/304131.html</trackback:ping><description><![CDATA[<p>綆$悊榪炴帴瀵硅薄<br /> Modle:biz,dao,entity<br /> 鏁版嵁婧愭帴鍙o細(xì)javax.sql.DataSource<br /> 寰楀埌<br /> javax.namming.Context鎺ュ彛鐨刲ookup()鏂規(guī)硶<br /> java:comp/env/jdbc/books</p> <p><br /> 1 Tomcat鐨刢onf/context.xml(Tomcat5.5浠ュ墠閰嶅湪server.xml涓?lt;host>鏍囩涓?<br />  <context><br />   <Resource name="jdbc/books"http://JNDI鍚嶇О<br />        auth="Container"http://榪炴帴姹犵敱璋佺鐞?container瀹屽叏鐢卞鍣ㄧ鐞?application鐢辯▼搴忕鐞?<br />        type="javax.sql.DataSource"http://鏁版嵁婧愮被鍨?br />        maxActive="100"http://鏈澶ц繛鎺?br />        maxIdle="30"http://鏈澶х┖闂?br />        maxWait="10000"http://鍗曚綅姣錛屾渶澶х瓑寰咃紝鏃犻檺絳夊緟鍊艱涓?1<br />        username="sa"<br />        password="accp"<br />        driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"<br />        url="jdbc:sqlserver://localhost:1433;databaseName=food"<br />         /><br />  </context></p> <p>2 鍔犳暟搴撴嵁椹卞姩jar<br /> -5.5浠ュ墠<br />  TomCat/comm/lib<br /> -5.5浠ュ悗<br />  TomCat/lib鐩綍涓?br />  </p> <p>3 緙栧啓浠g爜<br />  *javax.naming.context;<br />  *javax.naming.InitialContext;<br />  Connection conn;<br />  Statement stmt;<br />  ResultSet rs;<br />  try{<br />   Context ctx=new InitialContext();<br />   DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/books");<br />   conn=ds.getConnection();<br />   stmt=conn.createStatement();<br />   rs=stmt.executeQuery(sql);<br />  }catch(){}</p> <img src ="http://www.tkk7.com/ywj-316/aggbug/304131.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.tkk7.com/ywj-316/" target="_blank">junly</a> 2009-11-29 21:19 <a href="http://www.tkk7.com/ywj-316/archive/2009/11/29/304131.html#Feedback" target="_blank" style="text-decoration:none;">鍙戣〃璇勮</a></div>]]></description></item></channel></rss> <footer> <div class="friendship-link"> <p>感谢您访问我们的网站,您可能还对以下资源感兴趣:</p> <a href="http://www.tkk7.com/" title="亚洲av成人片在线观看">亚洲av成人片在线观看</a> <div class="friend-links"> </div> </div> </footer> 主站蜘蛛池模板: <a href="http://youketech.com" target="_blank">亚洲国产一区二区三区</a>| <a href="http://wwwst6.com" target="_blank">日韩吃奶摸下AA片免费观看</a>| <a href="http://137499.com" target="_blank">免费萌白酱国产一区二区</a>| <a href="http://delvheng.com" target="_blank">亚洲制服丝袜中文字幕</a>| <a href="http://saob19.com" target="_blank">成人免费无码视频在线网站</a>| <a href="http://34pmpm.com" target="_blank">亚洲va乱码一区二区三区</a>| <a href="http://wankufan.com" target="_blank">成人毛片免费观看视频大全</a>| <a href="http://6t23.com" target="_blank">99亚洲男女激情在线观看</a>| <a href="http://lfhuanxin.com" target="_blank">国产成人无码a区在线观看视频免费</a>| <a href="http://meiluniao.com" target="_blank">亚洲kkk4444在线观看</a>| <a href="http://h588888.com" target="_blank">国产精品二区三区免费播放心</a>| <a href="http://fantoment.com" target="_blank">日本亚洲欧美色视频在线播放 </a>| <a href="http://yisousou.com" target="_blank">九九99热免费最新版</a>| <a href="http://126cm.com" target="_blank">国产亚洲日韩一区二区三区</a>| <a href="http://ahjmdd.com" target="_blank">中文字幕在线免费视频</a>| <a href="http://t66ycom.com" target="_blank">亚洲av综合色区</a>| <a href="http://ti166.com" target="_blank">91精品国产免费入口</a>| <a href="http://fdsyjy.com" target="_blank">亚洲伊人精品综合在合线</a>| <a href="http://socgl.com" target="_blank">免费无码A片一区二三区</a>| <a href="http://yy12345.com" target="_blank">亚洲精品国产摄像头</a>| <a href="http://huianpawn.com" target="_blank">亚洲成?Ⅴ人在线观看无码</a>| <a href="http://youkabaitiao.com" target="_blank">国产免费久久久久久无码</a>| <a href="http://fsszx888.com" target="_blank">亚洲精品免费在线观看</a>| <a href="http://bovch.com" target="_blank">日韩一区二区a片免费观看</a>| <a href="http://69xjk.com" target="_blank">久久久久亚洲精品无码网址色欲 </a>| <a href="http://1897tao.com" target="_blank">1000部羞羞禁止免费观看视频</a>| <a href="http://922eee.com" target="_blank">亚洲午夜电影在线观看</a>| <a href="http://spxingyiquan.com" target="_blank">午夜一级毛片免费视频</a>| <a href="http://zzz477.com" target="_blank">a级毛片免费观看在线</a>| <a href="http://56ms.com" target="_blank">77777_亚洲午夜久久多人</a>| <a href="http://avqvod.com" target="_blank">无码视频免费一区二三区</a>| <a href="http://langya2255.com" target="_blank">少妇亚洲免费精品</a>| <a href="http://wlzp88.com" target="_blank">亚洲视频在线视频</a>| <a href="http://ttooyuyu.com" target="_blank">好爽又高潮了毛片免费下载</a>| <a href="http://9hao66.com" target="_blank">国产精品成人啪精品视频免费</a>| <a href="http://meijibear.com" target="_blank">亚洲一本综合久久</a>| <a href="http://popodino.com" target="_blank">免费网站看v片在线香蕉</a>| <a href="http://av56cc.com" target="_blank">在线观看免费视频一区</a>| <a href="http://71caoxee.com" target="_blank">亚洲精品一二三区</a>| <a href="http://goldwellib.com" target="_blank">亚洲人成网站18禁止一区</a>| <a href="http://chinahongfeng.com" target="_blank">3d动漫精品啪啪一区二区免费</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>