{"id":208,"date":"2007-09-07T00:00:00","date_gmt":"2007-09-07T00:00:00","guid":{"rendered":"http:\/\/www.strongd.net\/?p=208"},"modified":"2007-09-07T00:00:00","modified_gmt":"2007-09-07T00:00:00","slug":"Java SE 6 \u65b0\u7279\u6027: Java DB \u548c JDBC 4.0","status":"publish","type":"post","link":"https:\/\/www.strongd.net\/?p=208","title":{"rendered":"Java SE 6 \u65b0\u7279\u6027: Java DB \u548c JDBC 4.0"},"content":{"rendered":"<div>\n<blockquote>\n<p>2006 \u5e74\u5e95\uff0cSun \u516c\u53f8\u53d1\u5e03\u4e86 Java Standard Edition 6\uff08Java SE 6\uff09\u7684\u6700\u7ec8\u6b63\u5f0f\u7248\uff0c\u4ee3\u53f7 Mustang\uff08\u91ce\u9a6c\uff09\u3002\u8ddf Tiger\uff08Java SE 5\uff09\u76f8\u6bd4\uff0cMustang \u5728\u6027\u80fd\u65b9\u9762\u6709\u4e86\u4e0d\u9519\u7684\u63d0\u5347\u3002\u4e0e Tiger \u5728 API \u5e93\u65b9\u9762\u7684\u5927\u5e45\u5ea6\u52a0\u5f3a\u76f8\u6bd4\uff0c\u867d\u7136 Mustang \u5728 API \u5e93\u65b9\u9762\u7684\u65b0\u7279\u6027\u663e\u5f97\u4e0d\u592a\u591a\uff0c\u4f46\u662f\u4e5f\u63d0\u4f9b\u4e86\u8bb8\u591a\u5b9e\u7528\u548c\u65b9\u4fbf\u7684\u529f\u80fd\uff1a\u5728\u811a\u672c\uff0cWebService\uff0cXML\uff0c\u7f16\u8bd1\u5668 API\uff0c\u6570\u636e\u5e93\uff0cJMX\uff0c\u7f51\u7edc\u548c Instrumentation \u65b9\u9762\u90fd\u6709\u4e0d\u9519\u7684\u65b0\u7279\u6027\u548c\u529f\u80fd\u52a0\u5f3a\u3002 <a href=\"..\/list\/1\"><font color=\"#5c81a7\"><em>\u672c\u7cfb\u5217<\/em> <\/font><\/a>\u6587\u7ae0\u4e3b\u8981\u4ecb\u7ecd Java SE 6 \u5728 API \u5e93\u65b9\u9762\u7684\u90e8\u5206\u65b0\u7279\u6027\uff0c\u901a\u8fc7\u4e00\u4e9b\u4f8b\u5b50\u548c\u8bb2\u89e3\uff0c\u5e2e\u52a9\u5f00\u53d1\u8005\u5728\u7f16\u7a0b\u5b9e\u8df5\u5f53\u4e2d\u66f4\u597d\u7684\u8fd0\u7528 Java SE 6\uff0c\u63d0\u9ad8\u5f00\u53d1\u6548\u7387\u3002<\/p>\n<p>\u672c\u6587\u662f\u7cfb\u5217\u6587\u7ae0\u7684\u7b2c 5 \u7bc7\uff0c\u4ecb\u7ecd\u4e86 Java SE 6 \u5728\u6570\u636e\u5e93\u7f16\u7a0b\u65b9\u9762\u7684\u65b0\u7279\u6027\u3002<\/p>\n<\/blockquote>\n<p>\u957f\u4e45\u4ee5\u6765\uff0c\u7531\u4e8e\u5927\u91cf\uff08\u751a\u81f3\u51e0\u4e4e\u6240\u6709\uff09\u7684 Java \u5e94\u7528\u90fd\u4f9d\u8d56\u4e8e\u6570\u636e\u5e93\uff0c\u5982\u4f55\u4f7f\u7528 Java \u8bed\u8a00\u9ad8\u6548\u3001\u53ef\u9760\u3001\u7b80\u6d01\u5730\u8bbf\u95ee\u6570\u636e\u5e93\u4e00\u76f4\u662f\u7a0b\u5e8f\u5458\u4eec\u6d25\u6d25\u4e50\u9053\u7684\u8bdd\u9898\u3002\u65b0\u53d1\u5e03\u7684 Java SE 6 \u4e5f\u5728\u8fd9\u65b9\u9762\u66f4\u4e0a\u5c42\u697c\uff0c\u4e3a\u7f16\u7a0b\u4eba\u5458\u63d0\u4f9b\u4e86\u8bb8\u591a\u597d\u7528\u7684\u65b0\u7279\u6027\u3002\u5176\u4e2d\u6700\u663e\u8457\u7684\uff0c\u83ab\u8fc7\u4e8e Java SE 6 \u62e5\u6709\u4e86\u4e00\u4e2a\u5185\u5d4c\u7684 100% \u7528 Java \u8bed\u8a00\u7f16\u5199\u7684\u6570\u636e\u5e93\u7cfb\u7edf\u3002\u5e76\u4e14\uff0cJava 6 \u5f00\u59cb\u652f\u6301 JDBC 4.0 \u7684\u4e00\u7cfb\u5217\u65b0\u529f\u80fd\u548c\u5c5e\u6027\u3002\u8fd9\u6837\uff0cJava SE \u5728\u5bf9\u6301\u4e45\u6570\u636e\u7684\u8bbf\u95ee\u4e0a\u5c31\u663e\u5f97\u66f4\u4e3a\u6613\u7528\u548c\u5f3a\u5927\u4e86\u3002<\/p>\n<p><a name=\"N1005E\"><\/a><span class=\"atitle\">Java DB\uff1aJava 6 \u91cc\u7684\u6570\u636e\u5e93<\/span><\/p>\n<p>\u65b0\u5b89\u88c5\u4e86 JDK 6 \u7684\u7a0b\u5e8f\u5458\u4eec\u4e5f\u8bb8\u4f1a\u53d1\u73b0\uff0c\u9664\u4e86\u4f20\u7edf\u7684 bin\u3001jre \u7b49\u76ee\u5f55\uff0cJDK 6 \u65b0\u589e\u4e86\u4e00\u4e2a\u540d\u4e3a db \u7684\u76ee\u5f55\u3002\u8fd9\u4fbf\u662f Java 6 \u7684\u65b0\u6210\u5458\uff1aJava DB\u3002\u8fd9\u662f\u4e00\u4e2a\u7eaf Java \u5b9e\u73b0\u3001\u5f00\u6e90\u7684\u6570\u636e\u5e93\u7ba1\u7406\u7cfb\u7edf\uff08DBMS\uff09\uff0c\u6e90\u4e8e Apache \u8f6f\u4ef6\u57fa\u91d1\u4f1a\uff08ASF\uff09\u540d\u4e0b\u7684\u9879\u76ee Derby\u3002\u5b83\u53ea\u6709 2MB \u5927\u5c0f\uff0c\u5bf9\u6bd4\u52a8\u8f84\u4e0a G \u7684\u6570\u636e\u5e93\u6765\u8bf4\u53ef\u8c13\u8896\u73cd\u3002\u4f46\u8fd9\u5e76\u4e0d\u59a8\u788d Derby \u529f\u80fd\u9f50\u5907\uff0c\u652f\u6301\u51e0\u4e4e\u5927\u90e8\u5206\u7684\u6570\u636e\u5e93\u5e94\u7528\u6240\u9700\u8981\u7684\u7279\u6027\u3002\u66f4\u96be\u80fd\u53ef\u8d35\u7684\u662f\uff0c\u4f9d\u6258\u4e8e ASF \u5f3a\u5927\u7684\u793e\u533a\u529b\u91cf\uff0cDerby \u5f97\u5230\u4e86\u5305\u62ec IBM \u548c Sun \u7b49\u5927\u516c\u53f8\u4ee5\u53ca\u5168\u4e16\u754c\u4f18\u79c0\u7a0b\u5e8f\u5458\u4eec\u7684\u652f\u6301\u3002\u8fd9\u4e5f\u96be\u602a Sun \u516c\u53f8\u4f1a\u9009\u62e9\u5176 10.2.2 \u7248\u672c\u7eb3\u5165\u5230 JDK 6 \u4e2d\uff0c\u4f5c\u4e3a\u5185\u5d4c\u7684\u6570\u636e\u5e93\u3002\u8fd9\u5c31\u597d\u50cf\u4e3a JDK \u6ce8\u5165\u4e86\u4e00\u80a1\u5168\u65b0\u7684\u6d3b\u529b\uff1aJava \u7a0b\u5e8f\u5458\u4e0d\u518d\u9700\u8981\u8017\u8d39\u5927\u91cf\u7cbe\u529b\u5b89\u88c5\u548c\u914d\u7f6e\u6570\u636e\u5e93\uff0c\u5c31\u80fd\u8fdb\u884c\u5b89\u5168\u3001\u6613\u7528\u3001\u6807\u51c6\u3001\u5e76\u4e14\u514d\u8d39\u7684\u6570\u636e\u5e93\u7f16\u7a0b\u3002\u5728\u8fd9\u4e00\u7ae0\u4e2d\uff0c\u6211\u4eec\u5c06\u521d\u7aa5 Java DB \u7684\u4e16\u754c\uff0c\u6765\u63a2\u7a76\u5982\u4f55\u4f7f\u7528\u5b83\u7f16\u5199\u51fa\u529f\u80fd\u4e30\u5bcc\u7684\u7a0b\u5e8f\u3002<\/p>\n<p><a name=\"N10067\"><\/a><span class=\"smalltitle\"><strong><font size=\"3\">Hello, Java DB\uff1a\u5185\u5d4c\u6a21\u5f0f\u7684 Derby<\/font><\/strong><\/span><\/p>\n<p>\u65e2\u7136\u6709\u4e86\u5185\u5d4c\uff08embedded\uff09\u7684\u6570\u636e\u5e93\uff0c\u5c31\u8ba9\u6211\u4eec\u4ece\u4e00\u4e2a\u7b80\u5355\u7684\u8303\u4f8b\uff08\u4ee3\u7801\u5728 <a href=\"#list1\"><font color=\"#996699\">\u6e05\u5355 1<\/font><\/a> \u4e2d\u5217\u51fa\uff09\u5f00\u59cb\uff0c\u8bd5\u7740\u4f7f\u7528\u5b83\u5427\u3002\u8fd9\u4e2a\u7a0b\u5e8f\u505a\u4e86\u5927\u591a\u6570\u6570\u636e\u5e93\u5e94\u7528\u90fd\u53ef\u80fd\u4f1a\u505a\u7684\u64cd\u4f5c\uff1a\u5728 DBMS \u4e2d\u521b\u5efa\u4e86\u4e00\u4e2a\u540d\u4e3a helloDB \u7684\u6570\u636e\u5e93\uff1b\u521b\u5efa\u4e86\u4e00\u5f20\u6570\u636e\u8868\uff0c\u53d6\u540d\u4e3a hellotable\uff1b\u5411\u8868\u5185\u63d2\u5165\u4e86\u4e24\u6761\u6570\u636e\uff1b\u7136\u540e\uff0c\u67e5\u8be2\u6570\u636e\u5e76\u5c06\u7ed3\u679c\u6253\u5370\u5728\u63a7\u5236\u53f0\u4e0a\uff1b\u6700\u540e\uff0c\u5220\u9664\u8868\u548c\u6570\u636e\u5e93\uff0c\u91ca\u653e\u8d44\u6e90\u3002<\/p>\n<p><a name=\"list1\"><\/a><strong>\u6e05\u5355 1. HelloJavaDB \u7684\u4ee3\u7801<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">public class HelloJavaDB {<br \/>    public static void main(String[] args) {<br \/>        try { \/\/ load the driver<br \/>            Class.forName(&quot;org.apache.derby.jdbc.EmbeddedDriver&quot;).newInstance();<br \/>            System.out.println(&quot;Load the embedded driver&quot;);<br \/>            Connection conn = null;<br \/>            Properties props = new Properties();<br \/>            props.put(&quot;user&quot;, &quot;user1&quot;);<br \/>            props.put(&quot;password&quot;, &quot;user1&quot;);<br \/>            \/\/create and connect the database named helloDB<br \/>            conn=DriverManager.getConnection(&quot;jdbc:derby:helloDB;create=true&quot;, props);<br \/>            System.out.println(&quot;create and connect to helloDB&quot;);<br \/>            conn.setAutoCommit(false);<br \/>            \/\/ create a table and insert two records<br \/>            Statement s = conn.createStatement();<br \/>            s.execute(&quot;create table hellotable(name varchar(40), score int)&quot;);<br \/>            System.out.println(&quot;Created table hellotable&quot;);<br \/>            s.execute(&quot;insert into hellotable values(`Ruth Cao`, 86)&quot;);<br \/>            s.execute(&quot;insert into hellotable values (`Flora Shi`, 92)&quot;);<br \/>            \/\/ list the two records<br \/>            ResultSet rs = s.executeQuery(<br \/>               &quot;SELECT name, score FROM hellotable ORDER BY score&quot;);<br \/>            System.out.println(&quot;name\\t\\tscore&quot;);<br \/>            while(rs.next()) {<br \/>                StringBuilder builder = new StringBuilder(rs.getString(1));<br \/>                builder.append(&quot;\\t&quot;);<br \/>                builder.append(rs.getInt(2));<br \/>                System.out.println(builder.toString());<br \/>            }<br \/>            \/\/ delete the table<br \/>            s.execute(&quot;drop table hellotable&quot;);<br \/>            System.out.println(&quot;Dropped table hellotable&quot;);<br \/>            rs.close();<br \/>            s.close();<br \/>            System.out.println(&quot;Closed result set and statement&quot;);<br \/>            conn.commit();<br \/>            conn.close();<br \/>            System.out.println(&quot;Committed transaction and closed connection&quot;);<br \/>            try { \/\/ perform a clean shutdown<br \/>                 DriverManager.getConnection(&quot;jdbc:derby:;shutdown=true&quot;);<br \/>            } catch (SQLException se) {<br \/>                System.out.println(&quot;Database shut down normally&quot;);<br \/>            }<br \/>        } catch (Throwable e) {<br \/>            \/\/ handle the exception<br \/>        }<br \/>        System.out.println(&quot;SimpleApp finished&quot;);<br \/>    }<br \/>}<\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p>\u968f\u540e\uff0c\u6211\u4eec\u5728\u547d\u4ee4\u884c\uff08\u672c\u4f8b\u4e3a Windows \u5e73\u53f0\uff0c\u5f53\u7136\uff0c\u5176\u5b83\u7cfb\u7edf\u4e0b\u7a0d\u4f5c\u6539\u52a8\u5373\u53ef\uff09\u4e0b\u952e\u5165\u4ee5\u4e0b\u547d\u4ee4\uff1a<\/p>\n<p><a name=\"list2\"><\/a><strong>\u6e05\u5355 2. \u8fd0\u884c HelloJavaDB \u547d\u4ee4<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">                java &ndash;cp .;%JAVA_HOME%\\db\\lib\\derby.jar HelloJavaDB<\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p>\u7a0b\u5e8f\u5c06\u4f1a\u6309\u7167\u6211\u4eec\u9884\u60f3\u7684\u90a3\u6837\u6267\u884c\uff0c<a href=\"#fig001\"><font color=\"#996699\">\u56fe 1<\/font><\/a> \u662f\u6267\u884c\u7ed3\u679c\u7684\u4e00\u90e8\u5206\u622a\u5c4f\uff1a<\/p>\n<p><a name=\"fig001\"><\/a><strong>\u56fe 1. HelloJavaDB \u7a0b\u5e8f\u7684\u6267\u884c\u7ed3\u679c<\/strong><br \/><img decoding=\"async\" src=\"http:\/\/www.ibm.com\/developerworks\/cn\/java\/j-lo-jse65\/fig001.jpg\" alt=\"\u56fe 1. HelloJavaDB \u7a0b\u5e8f\u7684\u6267\u884c\u7ed3\u679c\" \/> <\/p>\n<p>\u4e0a\u8ff0\u7684\u7a0b\u5e8f\u548c\u4ee5\u5f80\u6ca1\u4ec0\u4e48\u533a\u522b\u3002\u4e0d\u540c\u7684\u662f\u6211\u4eec\u4e0d\u9700\u8981\u518d\u4e3a DBMS \u7684\u914d\u7f6e\u800c\u52b3\u795e\uff0c\u56e0\u4e3a Derby \u5df2\u7ecf\u81ea\u52a8\u5730\u5728\u5f53\u524d\u76ee\u5f55\u4e0b\u65b0\u5efa\u4e86\u4e00\u4e2a\u540d\u4e3a helloDB \u7684\u76ee\u5f55\uff0c\u6765\u7269\u7406\u5730\u5b58\u50a8\u6570\u636e\u548c\u65e5\u5fd7\u3002\u9700\u8981\u505a\u7684\u53ea\u662f\u6ce8\u610f\u547d\u540d\u95ee\u9898\uff1a\u5728\u5185\u5d4c\u6a21\u5f0f\u4e0b\u9a71\u52a8\u7684\u540d\u5b57\u5e94\u4e3a org.apache.derby.jdbc.EmbeddedDriver\uff1b\u521b\u5efa\u4e00\u4e2a\u65b0\u6570\u636e\u5e93\u65f6\u9700\u8981\u5728\u534f\u8bae\u540e\u52a0\u5165 create=true\u3002\u53e6\u5916\uff0c\u5173\u95ed\u6240\u6709\u6570\u636e\u5e93\u4ee5\u53ca Derby \u7684\u5f15\u64ce\u53ef\u4ee5\u4f7f\u7528\u4ee5\u4e0b\u4ee3\u7801\uff1a<\/p>\n<p><a name=\"list3\"><\/a><strong>\u6e05\u5355 3. \u5173\u95ed\u6240\u6709\u6570\u636e\u5e93\u53ca Derby \u5f15\u64ce<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">                DriverManager.getConnection(&quot;jdbc:derby:;shutdown=true&quot;);<\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p>\u5982\u679c\u53ea\u60f3\u5173\u95ed\u4e00\u4e2a\u6570\u636e\u5e93\uff0c\u90a3\u4e48\u5219\u53ef\u4ee5\u8c03\u7528\uff1a<\/p>\n<p><a name=\"list4\"><\/a><strong>\u6e05\u5355 4. \u5173\u95ed\u4e00\u4e2a\u6570\u636e\u5e93<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">                DriverManager.getConnection(&quot;jdbc:derby:helloDB;shutdown=true &quot;);<\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p>\u8fd9\u6837\uff0c\u4f7f\u7528\u5d4c\u5165\u6a21\u5f0f\u7684 Derby \u7ef4\u62a4\u548c\u7ba1\u7406\u6570\u636e\u5e93\u7684\u6210\u672c\u63a5\u8fd1\u4e8e 0\u3002\u8fd9\u5bf9\u4e8e\u5e0c\u671b\u4e13\u5fc3\u5199\u4ee3\u7801\u7684\u4eba\u6765\u8bf4\u4e0d\u5931\u4e3a\u4e00\u4e2a\u597d\u6d88\u606f\u3002\u7136\u800c\u6709\u4eba\u4e0d\u7981\u8981\u95ee\uff1a\u65e2\u7136\u6709\u4e86\u5185\u5d4c\u6a21\u5f0f\uff0c\u4e3a\u4ec0\u4e48\u5927\u591a\u6570\u7684 DBMS \u90fd\u6ca1\u6709\u91c7\u53d6\u8fd9\u6837\u7684\u6a21\u5f0f\u5462\uff1f\u4e0d\u59a8\u505a\u4e00\u4e2a\u5c0f\u5b9e\u9a8c\u3002\u5f53\u6211\u4eec\u540c\u65f6\u5728\u4e24\u4e2a\u547d\u4ee4\u884c\u7a97\u53e3\u4e0b\u8fd0\u884c HelloJavaDB \u7a0b\u5e8f\u3002\u7ed3\u679c\u4e00\u4e2a\u7684\u7ed3\u679c\u4e0e\u521a\u624d\u4e00\u81f4\uff0c\u800c\u53e6\u4e00\u4e2a\u5374\u51fa\u73b0\u4e86\u9519\u8bef\uff0c\u5982 <a href=\"#fig002\"><font color=\"#996699\">\u56fe 2<\/font><\/a> \u6240\u793a\u3002<\/p>\n<p><a name=\"fig002\"><\/a><strong>\u56fe 2. \u5185\u5d4c\u6a21\u5f0f\u7684\u5c40\u9650<\/strong><br \/><img decoding=\"async\" src=\"http:\/\/www.ibm.com\/developerworks\/cn\/java\/j-lo-jse65\/fig002.jpg\" alt=\"\u56fe 2. \u5185\u5d4c\u6a21\u5f0f\u7684\u5c40\u9650\" \/> <\/p>\n<p>\u9519\u8bef\u7684\u539f\u56e0\u5176\u5b9e\u5f88\u7b80\u5355\uff1a\u5728\u4f7f\u7528\u5185\u5d4c\u6a21\u5f0f\u65f6\uff0cDerby \u672c\u8eab\u5e76\u4e0d\u4f1a\u5728\u4e00\u4e2a\u72ec\u7acb\u7684\u8fdb\u7a0b\u4e2d\uff0c\u800c\u662f\u548c\u5e94\u7528\u7a0b\u5e8f\u4e00\u8d77\u5728\u540c\u4e00\u4e2a Java \u865a\u62df\u673a\uff08JVM\uff09\u91cc\u8fd0\u884c\u3002\u56e0\u6b64\uff0cDerby \u5982\u540c\u5e94\u7528\u6240\u4f7f\u7528\u7684\u5176\u5b83 jar \u6587\u4ef6\u4e00\u6837\u53d8\u6210\u4e86\u5e94\u7528\u7684\u4e00\u90e8\u5206\u3002\u8fd9\u5c31\u4e0d\u96be\u7406\u89e3\u4e3a\u4ec0\u4e48\u5728 classpath \u4e2d\u52a0\u5165 derby \u7684 jar \u6587\u4ef6\uff0c\u6211\u4eec\u7684\u793a\u4f8b\u7a0b\u5e8f\u5c31\u80fd\u591f\u987a\u5229\u8fd0\u884c\u4e86\u3002\u8fd9\u4e5f\u8bf4\u660e\u4e86\u53ea\u6709\u4e00\u4e2a JVM \u80fd\u591f\u542f\u52a8\u6570\u636e\u5e93\uff1a\u800c\u4e24\u4e2a\u8dd1\u5728\u4e0d\u540c JVM \u5b9e\u4f8b\u91cc\u7684\u5e94\u7528\u81ea\u7136\u5c31\u4e0d\u80fd\u591f\u8bbf\u95ee\u540c\u4e00\u4e2a\u6570\u636e\u5e93\u4e86\u3002<\/p>\n<p>\u9274\u4e8e\u4e0a\u8ff0\u7684\u5c40\u9650\u6027\uff0c\u548c\u6765\u81ea\u4e0d\u540c JVM \u7684\u591a\u4e2a\u8fde\u63a5\u60f3\u8bbf\u95ee\u4e00\u4e2a\u6570\u636e\u5e93\u7684\u9700\u6c42\uff0c\u4e0b\u4e00\u8282\u5c06\u4ecb\u7ecd Derby \u7684\u53e6\u4e00\u79cd\u6a21\u5f0f\uff1a\u7f51\u7edc\u670d\u52a1\u5668\uff08Network Server\uff09\u3002<\/p>\n<p><a name=\"N100D4\"><\/a><span class=\"smalltitle\"><strong><font size=\"3\">\u7f51\u7edc\u670d\u52a1\u5668\u6a21\u5f0f<\/font><\/strong><\/span><\/p>\n<p>\u5982\u4e0a\u6240\u8ff0\uff0c\u7f51\u7edc\u670d\u52a1\u5668\u6a21\u5f0f\u662f\u4e00\u79cd\u66f4\u4e3a\u4f20\u7edf\u7684\u5ba2\u6237\u7aef\/\u670d\u52a1\u5668\u6a21\u5f0f\u3002\u6211\u4eec\u9700\u8981\u542f\u52a8\u4e00\u4e2a Derby \u7684\u7f51\u7edc\u670d\u52a1\u5668\u7528\u4e8e\u5904\u7406\u5ba2\u6237\u7aef\u7684\u8bf7\u6c42\uff0c\u4e0d\u8bba\u8fd9\u4e9b\u8bf7\u6c42\u662f\u6765\u81ea\u540c\u4e00\u4e2a JVM \u5b9e\u4f8b\uff0c\u8fd8\u662f\u6765\u81ea\u4e8e\u7f51\u7edc\u4e0a\u7684\u53e6\u4e00\u53f0\u673a\u5668\u3002\u540c\u65f6\uff0c\u5ba2\u6237\u7aef\u4f7f\u7528 DRDA\uff08Distributed Relational Database Architecture\uff09\u534f\u8bae\u8fde\u63a5\u5230\u670d\u52a1\u5668\u7aef\u3002\u8fd9\u662f\u4e00\u4e2a\u7531 The Open Group \u5021\u5bfc\u7684\u6570\u636e\u5e93\u4ea4\u4e92\u6807\u51c6\u3002<a href=\"#fig003\"><font color=\"#996699\">\u56fe 3<\/font><\/a> \u8bf4\u660e\u4e86\u8be5\u6a21\u5f0f\u7684\u5927\u4f53\u7ed3\u6784\u3002<\/p>\n<p>\u7531\u4e8e Derby \u7684\u5f00\u53d1\u8005\u4eec\u52aa\u529b\u4f7f\u5f97\u7f51\u7edc\u670d\u52a1\u5668\u6a21\u5f0f\u4e0e\u5185\u5d4c\u6a21\u5f0f\u4e4b\u95f4\u7684\u5dee\u5f02\u53d8\u5c0f\uff0c\u4f7f\u5f97\u6211\u4eec\u53ea\u9700\u7b80\u5355\u5730\u4fee\u6539 <a href=\"#list1\"><font color=\"#996699\">\u6e05\u5355 1<\/font><\/a> \u4e2d\u7684\u7a0b\u5e8f\u5c31\u53ef\u4ee5\u5b9e\u73b0\u3002\u5982 <a href=\"#list5\"><font color=\"#996699\">\u6e05\u5355 5<\/font><\/a>\u6240\u793a\uff0c\u6211\u4eec\u5728 HelloJavaDB \u4e2d\u589e\u6dfb\u4e86\u4e00\u4e2a\u65b0\u7684\u51fd\u6570\u548c\u4e00\u4e9b\u5b57\u7b26\u4e32\u53d8\u91cf\u3002\u4e0d\u96be\u770b\u51fa\uff0c\u65b0\u7684\u4ee3\u7801\u53ea\u662f\u5c06\u4e00\u4e9b\u5728 \u4e0a\u4e00\u8282\u4e2d\u7279\u522b\u6307\u51fa\u7684\u5b57\u7b26\u4e32\u8fdb\u884c\u4e86\u66f4\u6539\uff1a\u9a71\u52a8\u7c7b\u4e3a org.apache.derby.jdbc.ClientDriver\uff0c\u800c\u8fde\u63a5\u6570\u636e\u5e93\u7684\u534f\u8bae\u5219\u53d8\u6210\u4e86 jdbc:derby:\/\/localhost:1527\/\u3002\u8fd9\u662f\u4e00\u4e2a\u7c7b\u4f3c URL \u7684\u5b57\u7b26\u4e32\uff0c\u800c\u4e8b\u5b9e\u4e0a\uff0cDerby \u7f51\u7edc\u7684\u5ba2\u6237\u7aef\u7684\u8fde\u63a5\u683c\u5f0f\u4e3a\uff1ajdbc:derby:\/\/server[:port]\/databaseName[;attributeKey=value]\u3002\u5728\u8fd9\u4e2a\u4f8b\u5b50\u4e2d\uff0c\u6211\u4eec\u4f7f\u7528\u4e86\u6700\u7b80\u5355\u7684\u672c\u5730\u673a\u5668\u4f5c\u4e3a\u670d\u52a1\u5668\uff0c\u800c\u7aef\u53e3\u5219\u662f Derby \u9ed8\u8ba4\u7684 1527 \u7aef\u53e3\u3002<\/p>\n<p><a name=\"fig003\"><\/a><strong>\u56fe 3. Derby \u7f51\u7edc\u670d\u52a1\u5668\u6a21\u5f0f\u67b6\u6784<\/strong><br \/><img decoding=\"async\" src=\"http:\/\/www.ibm.com\/developerworks\/cn\/java\/j-lo-jse65\/fig003.gif\" alt=\"\u56fe 3. Derby \u7f51\u7edc\u670d\u52a1\u5668\u6a21\u5f0f\u67b6\u6784\" \/> <\/p>\n<p><a name=\"list5\"><\/a><strong>\u6e05\u5355 5. \u7f51\u7edc\u670d\u52a1\u5668\u6a21\u5f0f\u4e0b\u7684 HelloJavaDB<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">public class HelloJavaDB {<br \/>    public static String driver = &quot;org.apache.derby.jdbc.EmbeddedDriver&quot$$<br \/>    public static String protocol = &quot;jdbc:derby:&quot$$<br \/>    public static void main(String[] args) {<br \/>        \/\/ same as before <br \/>    }<br \/>    private static void parseArguments(String[] args) {<br \/>        if (args.length == 0 || args.length &gt; 1) {<br \/>            return;<br \/>        }<br \/>        if (args[0].equalsIgnoreCase(&quot;derbyclient&quot;)) {<br \/>            framework = &quot;derbyclient&quot$$<br \/>            driver = &quot;org.apache.derby.jdbc.ClientDriver&quot$$<br \/>            protocol = &quot;jdbc:derby:\/\/localhost:1527\/&quot$$<br \/>        }<br \/>    }<br \/>}<\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p>\u5f53\u7136\uff0c\u4ec5\u4ec5\u6709\u5ba2\u6237\u7aef\u662f\u4e0d\u591f\u7684\uff0c\u6211\u4eec\u8fd8\u9700\u8981\u542f\u52a8\u7f51\u7edc\u670d\u52a1\u5668\u3002Derby \u4e2d\u63a7\u5236\u7f51\u7edc\u670d\u52a1\u5668\u7684\u7c7b\u662f org.apache.derby.drda.NetworkServerControl\uff0c\u56e0\u6b64\u952e\u5165\u4ee5\u4e0b\u547d\u4ee4\u5373\u53ef\u3002\u5982\u679c\u60f3\u4e86\u89e3 NetworkServerControl \u66f4\u591a\u7684\u9009\u9879\uff0c\u53ea\u8981\u628a start \u53c2\u6570\u53bb\u6389\u5c31\u53ef\u4ee5\u770b\u5230\u5e2e\u52a9\u4fe1\u606f\u4e86\u3002\u5173\u4e8e\u7f51\u7edc\u670d\u52a1\u5668\u7aef\u7684\u5b9e\u73b0\uff0c\u90fd\u88ab Derby \u5305\u542b\u5728 derbynet.jar \u91cc\u3002<\/p>\n<p><a name=\"list6\"><\/a><strong>\u6e05\u5355 6. \u542f\u52a8\u7f51\u7edc\u670d\u52a1\u5668<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">java -cp .;&quot;C:\\Program Files\\Java\\jdk1.6.0\\db\\lib\\derby.jar&quot$$<br \/> &quot;C:\\Program Files\\Java\\jdk1.6.0\\db\\lib\\derbynet.jar&quot;<br \/> org.apache.derby.drda.NetworkServerControl start<\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p>\u76f8\u5bf9\u5e94\u7684\uff0c\u7f51\u7edc\u5ba2\u6237\u7aef\u7684\u5b9e\u73b0\u88ab\u5305\u542b\u5728 derbyclient.jar \u4e2d\u3002\u6240\u4ee5\uff0c\u53ea\u9700\u8981\u5728 classpath \u4e2d\u52a0\u5165\u8be5 jar \u6587\u4ef6\uff0c\u4fee\u6539\u540e\u7684\u5ba2\u6237\u7aef\u5c31\u53ef\u4ee5\u987a\u5229\u5730\u8bfb\u53d6\u6570\u636e\u4e86\u3002\u518d\u4e00\u6b21\u5c1d\u8bd5\u7740\u4f7f\u7528\u4e24\u4e2a\u547d\u4ee4\u884c\u7a97\u53e3\u53bb\u8fde\u63a5\u6570\u636e\u5e93\uff0c\u5c31\u80fd\u591f\u5f97\u5230\u6b63\u786e\u7684\u7ed3\u679c\u4e86\u3002\u5982\u679c\u4e0d\u518d\u9700\u8981\u670d\u52a1\u5668\uff0c\u90a3\u4e48\u4f7f\u7528 NetworkServerControl \u7684 shutdown \u53c2\u6570\u5c31\u80fd\u591f\u5173\u95ed\u670d\u52a1\u5668\u3002<\/p>\n<p><a name=\"N10123\"><\/a><span class=\"smalltitle\"><strong><font size=\"3\">\u66f4\u591a<\/font><\/strong><\/span><\/p>\n<p>\u81f3\u6b64\uff0c\u6587\u7ae0\u4ecb\u7ecd\u4e86 Java SE 6 \u4e2d\u7684\u65b0\u6210\u5458\uff1aJava DB\uff08Derby\uff09\uff0c\u4e5f\u4ecb\u7ecd\u4e86\u5982\u4f55\u5728\u5185\u5d4c\u6a21\u5f0f\u4ee5\u53ca\u7f51\u7edc\u670d\u52a1\u5668\u6a21\u5f0f\u4e0b\u4f7f\u7528 Java DB\u3002\u5f53\u7136\u8fd9\u53ea\u662f\u6d45\u5c1d\u8f84\u6b62\uff0c\u66f4\u591a\u9ad8\u7ea7\u7684\u9009\u9879\u8fd8\u9700\u8981\u5728 Sun \u548c Derby \u7684\u6587\u6863\u4e2d\u5bfb\u627e\u3002\u5728\u8fd9\u4e00\u7ae0\u7684\u6700\u540e\uff0c\u6211\u4eec\u5c06\u7b80\u5355\u4ecb\u7ecd\u51e0\u4e2a Java DB \u7684\u5c0f\u5de5\u5177\u6765\u52a0\u5feb\u5f00\u53d1\u901f\u5ea6\u3002\u5b83\u4eec\u90fd\u4f4d\u4e8e org.apache.derby.tools \u5305\u5185\uff0c\u5728\u5f00\u53d1\u8fc7\u7a0b\u4e2d\u9700\u8981\u83b7\u53d6\u4fe1\u606f\u6216\u8005\u6d4b\u8bd5\u53ef\u4ee5\u7528\u5230\u3002<\/p>\n<ul>\n<li><strong>ij<\/strong>\uff1a\u4e00\u4e2a\u7528\u6765\u8fd0\u884c SQL \u811a\u672c\u7684\u5de5\u5177\uff1b <\/li>\n<li><strong>dblook<\/strong>\uff1a\u4e3a Derby \u6570\u636e\u5e93\u4f5c\u6a21\u5f0f\u63d0\u53d6\uff08Schema extraction\uff09\uff0c\u751f\u6210 DDL \u7684\u5de5\u5177\uff1b <\/li>\n<li><strong>sysinfo<\/strong>\uff1a\u663e\u793a\u7cfb\u7edf\u4ee5\u53ca Derby \u4fe1\u606f\u7684\u5de5\u5177\u7c7b\uff1b <\/li>\n<\/ul>\n<p><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td><img decoding=\"async\" src=\"http:\/\/www.ibm.com\/i\/v14\/rules\/blue_rule.gif\" alt=\"\" width=\"100%\" height=\"1\" \/><br \/><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/www.ibm.com\/i\/c.gif\" border=\"0\" alt=\"\" width=\"8\" height=\"6\" \/><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" class=\"no-print\" align=\"right\">\n<tbody>\n<tr align=\"right\">\n<td><img decoding=\"async\" src=\"http:\/\/www.ibm.com\/i\/c.gif\" alt=\"\" width=\"100%\" height=\"4\" \/><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td valign=\"middle\"><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/www.ibm.com\/i\/v14\/icons\/u_bold.gif\" border=\"0\" alt=\"\" width=\"16\" height=\"16\" \/><\/td>\n<td align=\"right\" valign=\"top\"><a href=\"#main\"><strong><font color=\"#996699\">\u56de\u9875\u9996<\/font><\/strong><\/a><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><a name=\"N10140\"><\/a><span class=\"atitle\">JDBC 4.0\uff1a\u65b0\u529f\u80fd\uff0c\u65b0 API<\/span><\/p>\n<p>\u5982\u679c\u8bf4\u4e0a\u4e00\u7ae0\u4ecb\u7ecd\u4e86 Java 6 \u4e2d\u7684\u4e00\u4e2a\u65b0\u6210\u5458\uff0c\u5b83\u672c\u6765\u5c31\u5b58\u5728\uff0c\u4f46\u662f\u6ca1\u6709\u88ab\u52a0\u5165\u8fdb JDK\u3002\u90a3\u4e48\u8fd9\u4e00\u7ae0\uff0c\u6211\u4eec\u5c06\u5173\u6ce8\u5728 JDBC 4.0 \u4e2d\u53c8\u589e\u52a0\u4e86\u54ea\u4e9b\u65b0\u529f\u80fd\u4ee5\u53ca\u4e0e\u4e4b\u76f8\u5bf9\u5e94\u7684\u65b0 API\u3002 <\/p>\n<p><a name=\"N10148\"><\/a><span class=\"smalltitle\"><strong><font size=\"3\">\u81ea\u52a8\u52a0\u8f7d\u9a71\u52a8<\/font><\/strong><\/span><\/p>\n<p>\u5728 JDBC 4.0 \u4e4b\u524d\uff0c\u7f16\u5199 JDBC \u7a0b\u5e8f\u90fd\u9700\u8981\u52a0\u4e0a\u4ee5\u4e0b\u8fd9\u53e5\u6709\u70b9\u4e11\u964b\u7684\u4ee3\u7801\uff1a<\/p>\n<p><a name=\"list7\"><\/a><strong>\u6e05\u5355 7. \u6ce8\u518c JDBC \u9a71\u52a8<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">                Class.forName(&quot;org.apache.derby.jdbc.EmbeddedDriver&quot;).newInstance();<\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p>Java.sql.DriverManager \u7684\u5185\u90e8\u5b9e\u73b0\u673a\u5236\u51b3\u5b9a\u4e86\u8fd9\u6837\u4ee3\u7801\u7684\u51fa\u73b0\u3002\u53ea\u6709\u5148\u901a\u8fc7 Class.forName \u627e\u5230\u7279\u5b9a\u9a71\u52a8\u7684 class \u6587\u4ef6\uff0cDriverManager.getConnection \u65b9\u6cd5\u624d\u80fd\u987a\u5229\u5730\u83b7\u5f97 Java \u5e94\u7528\u548c\u6570\u636e\u5e93\u7684\u8fde\u63a5\u3002\u8fd9\u6837\u7684\u4ee3\u7801\u4e3a\u7f16\u5199\u7a0b\u5e8f\u589e\u52a0\u4e86\u4e0d\u5fc5\u8981\u7684\u8d1f\u62c5\uff0cJDK \u7684\u5f00\u53d1\u8005\u4e5f\u610f\u8bc6\u5230\u4e86\u8fd9\u4e00\u70b9\u3002\u4ece Java 6 \u5f00\u59cb\uff0c\u5e94\u7528\u7a0b\u5e8f\u4e0d\u518d\u9700\u8981\u663e\u5f0f\u5730\u52a0\u8f7d\u9a71\u52a8\u7a0b\u5e8f\u4e86\uff0cDriverManager \u5f00\u59cb\u80fd\u591f\u81ea\u52a8\u5730\u627f\u62c5\u8fd9\u9879\u4efb\u52a1\u3002\u4f5c\u4e3a\u8bd5\u9a8c\uff0c\u6211\u4eec\u53ef\u4ee5\u5c06 <a href=\"#list1\"><font color=\"#996699\">\u6e05\u5355 1<\/font><\/a> \u4e2d\u7684\u76f8\u5173\u4ee3\u7801\u5220\u9664\uff0c\u91cd\u65b0\u7f16\u8bd1\u540e\u5728 JRE 6.0 \u4e0b\u8fd0\u884c\uff0c\u7ed3\u679c\u548c\u539f\u5148\u7684\u7a0b\u5e8f\u4e00\u6837\u3002<\/p>\n<p>\u597d\u5947\u7684\u8bfb\u8005\u4e5f\u8bb8\u4f1a\u95ee\uff0cDriverManager \u4e3a\u4ec0\u4e48\u80fd\u591f\u505a\u5230\u81ea\u52a8\u52a0\u8f7d\u5462\uff1f\u8fd9\u5c31\u8981\u5f52\u529f\u4e8e\u4e00\u79cd\u88ab\u79f0\u4e3a Service Provider \u7684\u65b0\u673a\u5236\u3002\u719f\u6089 Java \u5b89\u5168\u7f16\u7a0b\u7684\u7a0b\u5e8f\u5458\u53ef\u80fd\u5bf9\u5176\u5df2\u7ecf\u662f\u53f8\u7a7a\u89c1\u60ef\uff0c\u800c\u5b83\u73b0\u5728\u53c8\u51fa\u73b0\u5728 JDBC \u6a21\u5757\u4e2d\u3002JDBC 4.0 \u7684\u89c4\u8303\u89c4\u5b9a\uff0c\u6240\u6709 JDBC 4.0 \u7684\u9a71\u52a8 jar \u6587\u4ef6\u5fc5\u987b\u5305\u542b\u4e00\u4e2a java.sql.Driver\uff0c\u5b83\u4f4d\u4e8e jar \u6587\u4ef6\u7684 META-INF\/services \u76ee\u5f55\u4e0b\u3002\u8fd9\u4e2a\u6587\u4ef6\u91cc\u6bcf\u4e00\u884c\u4fbf\u63cf\u8ff0\u4e86\u4e00\u4e2a\u5bf9\u5e94\u7684\u9a71\u52a8\u7c7b\u3002\u5176\u5b9e\uff0c\u7f16\u5199\u8fd9\u4e2a\u6587\u4ef6\u7684\u65b9\u5f0f\u548c\u7f16\u5199\u4e00\u4e2a\u53ea\u6709\u5173\u952e\u5b57\uff08key\uff09\u800c\u6ca1\u6709\u503c\uff08value\uff09\u7684 properties \u6587\u4ef6\u7c7b\u4f3c\u3002\u540c\u6837\u5730\uff0c&lsquo;#&rsquo;\u4e4b\u540e\u7684\u6587\u5b57\u88ab\u8ba4\u4e3a\u662f\u6ce8\u91ca\u3002\u6709\u4e86\u8fd9\u6837\u7684\u63cf\u8ff0\uff0cDriverManager \u5c31\u53ef\u4ee5\u4ece\u5f53\u524d\u5728 CLASSPATH \u4e2d\u7684\u9a71\u52a8\u6587\u4ef6\u4e2d\u627e\u5230\uff0c\u5b83\u5e94\u8be5\u53bb\u52a0\u8f7d\u54ea\u4e9b\u7c7b\u3002\u800c\u5982\u679c\u6211\u4eec\u5728 CLASSPATH \u91cc\u6ca1\u6709\u4efb\u4f55 JDBC 4.0 \u7684\u9a71\u52a8\u6587\u4ef6\u7684\u60c5\u51b5\u4e0b\uff0c\u8c03\u7528 <a href=\"#list8\"><font color=\"#996699\">\u6e05\u5355 8<\/font><\/a> \u4e2d\u7684\u4ee3\u7801\u4f1a\u8f93\u51fa\u4e00\u4e2a sun.jdbc.odbc.JdbcOdbcDriver \u7c7b\u578b\u7684\u5bf9\u8c61\u3002\u800c\u4ed4\u7ec6\u6d4f\u89c8 JDK 6 \u7684\u76ee\u5f55\uff0c\u8fd9\u4e2a\u7c7b\u578b\u6b63\u662f\u5728 %JAVA_HOME%\/jre\/lib\/resources.jar \u7684 META-INF\/services \u76ee\u5f55\u4e0b\u7684 java.sql.Driver \u6587\u4ef6\u4e2d\u63cf\u8ff0\u7684\u3002\u4e5f\u5c31\u662f\u8bf4\uff0c\u8fd9\u662f JDK \u4e2d\u9ed8\u8ba4\u7684\u9a71\u52a8\u3002\u800c\u5982\u679c\u5f00\u53d1\u4eba\u5458\u60f3\u4f7f\u5f97\u81ea\u5df1\u7684\u9a71\u52a8\u4e5f\u80fd\u591f\u88ab DriverManager \u627e\u5230\uff0c\u53ea\u9700\u8981\u5c06\u5bf9\u5e94\u7684 jar \u6587\u4ef6\u52a0\u5165\u5230 CLASSPATH \u4e2d\u5c31\u53ef\u4ee5\u4e86\u3002\u5f53\u7136\uff0c\u5bf9\u4e8e\u90a3\u4e9b JDBC 4.0 \u4e4b\u524d\u7684\u9a71\u52a8\u6587\u4ef6\uff0c\u6211\u4eec\u8fd8\u662f\u53ea\u80fd\u663e\u5f0f\u5730\u53bb\u52a0\u8f7d\u4e86\u3002<\/p>\n<p><a name=\"list8\"><\/a><strong>\u6e05\u5355 8. \u7f57\u5217\u672c\u5730\u673a\u5668\u4e0a\u7684 JDBC \u9a71\u52a8<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">Enumeration&lt;Driver&gt; drivers = DriverManager.getDrivers();<br \/>while(drivers.hasMoreElements()) {<br \/>    System.out.println(drivers.nextElement());<br \/>}<\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p><a name=\"rowid\"><\/a><span class=\"smalltitle\"><strong><font size=\"3\">RowId<\/font><\/strong><\/span><\/p>\n<p>\u719f\u6089 DB2\u3001Oracle \u7b49\u5927\u578b DBMS \u7684\u4eba\u4e00\u5b9a\u4e0d\u4f1a\u5bf9 ROWID \u8fd9\u4e2a\u6982\u5ff5\u964c\u751f\uff1a\u5b83\u662f\u6570\u636e\u8868\u4e2d\u4e00\u4e2a&ldquo;\u9690\u85cf&rdquo;\u7684\u5217\uff0c\u662f\u6bcf\u4e00\u884c\u72ec\u4e00\u65e0\u4e8c\u7684\u6807\u8bc6\uff0c\u8868\u660e\u8fd9\u4e00\u884c\u7684\u7269\u7406\u6216\u8005\u903b\u8f91\u4f4d\u7f6e\u3002\u7531\u4e8e ROWID \u7c7b\u578b\u7684\u5e7f\u6cdb\u4f7f\u7528\uff0cJava SE 6 \u4e2d\u65b0\u589e\u4e86 java.sql.RowId \u7684\u6570\u636e\u7c7b\u578b\uff0c\u5141\u8bb8 JDBC \u7a0b\u5e8f\u80fd\u591f\u8bbf\u95ee SQL \u4e2d\u7684 ROWID \u7c7b\u578b\u3002\u8bda\u7136\uff0c\u4e0d\u662f\u6240\u6709\u7684 DBMS \u90fd\u652f\u6301 ROWID \u7c7b\u578b\u3002\u5373\u4f7f\u652f\u6301\uff0c\u4e0d\u540c\u7684 ROWID \u4e5f\u4f1a\u6709\u4e0d\u540c\u7684\u751f\u547d\u5468\u671f\u3002\u56e0\u6b64\u4f7f\u7528 DatabaseMetaData.getRowIdLifetime \u6765\u5224\u65ad\u7c7b\u578b\u7684\u751f\u547d\u5468\u671f\u4e0d\u5931\u4e3a\u4e00\u9879\u826f\u597d\u7684\u5b9e\u8df5\u7ecf\u9a8c\u3002\u6211\u4eec\u5728 <a href=\"#list1\"><font color=\"#996699\">\u6e05\u5355 1<\/font><\/a> \u7684\u7a0b\u5e8f\u83b7\u5f97\u8fde\u63a5\u4e4b\u540e\u589e\u52a0\u4ee5\u4e0b\u4ee3\u7801\uff0c\u4fbf\u53ef\u4ee5\u4e86\u89e3 ROWID \u7c7b\u578b\u7684\u652f\u6301\u60c5\u51b5\u3002<\/p>\n<p><a name=\"list9\"><\/a><strong>\u6e05\u5355 9. \u4e86\u89e3 ROWID \u7c7b\u578b\u7684\u652f\u6301\u60c5\u51b5<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">DatabaseMetaData meta = conn.getMetaData();System.out.println(meta.getRowIdLifetime());<\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p>Java SE 6 \u7684 API \u89c4\u8303\u4e2d\uff0cjava.sql.RowIdLifetime \u89c4\u5b9a\u4e86 5 \u79cd\u4e0d\u540c\u7684\u751f\u547d\u5468\u671f\uff1aROWID_UNSUPPORTED\u3001ROWID_VALID_FOREVER\u3001ROWID_VALID_OTHER\u3001ROWID_VALID_SESSION \u548c ROWID_VALID_TRANSACTION\u3002\u4ece\u5b57\u9762\u4e0a\u4e0d\u96be\u7406\u89e3\u5b83\u4eec\u8868\u793a\u4e86\u4e0d\u652f\u6301 ROWID\u3001ROWID \u6c38\u8fdc\u6709\u6548\u7b49\u7b49\u3002\u5177\u4f53\u7684\u4fe1\u606f\uff0c\u8fd8\u53ef\u4ee5\u53c2\u770b\u76f8\u5173\u7684 JavaDoc\u3002\u8bfb\u8005\u53ef\u4ee5\u5c1d\u8bd5\u7740\u8fde\u63a5 Derby \u8fdb\u884c\u8bd5\u9a8c\uff0c\u4f1a\u53d1\u73b0\u8fd0\u884c\u7ed3\u679c\u662f ROWID_UNSUPPORTED \uff0c\u5373 Derby \u5e76\u4e0d\u652f\u6301 ROWID\u3002<\/p>\n<p>\u65e2\u7136\u63d0\u4f9b\u4e86\u65b0\u7684\u6570\u636e\u7c7b\u578b\uff0c\u90a3\u4e48\u4e00\u4e9b\u76f8\u5e94\u7684\u83b7\u53d6\u3001\u66f4\u65b0\u6570\u636e\u8868\u5185\u5bb9\u7684\u65b0 API \u4e5f\u5728 Java 6 \u4e2d\u88ab\u6dfb\u52a0\u8fdb\u6765\u3002\u548c\u5176\u5b83\u5df2\u6709\u7684\u7c7b\u578b\u4e00\u6837\uff0c\u5728\u5f97\u5230 ResultSet \u6216\u8005 CallableStatement \u4e4b\u540e\uff0c\u8c03\u7528 get\/set\/update \u65b9\u6cd5\u5f97\u5230\/\u8bbe\u7f6e\/\u66f4\u65b0 RowId \u5bf9\u8c61\uff0c\u793a\u4f8b\u7684\u4ee3\u7801\u5982 <a href=\"#list10\"><font color=\"#996699\">\u6e05\u5355 10<\/font><\/a> \u6240\u793a\u3002<\/p>\n<p><a name=\"list10\"><\/a><strong>\u6e05\u5355 10. \u83b7\u5f97\/\u8bbe\u7f6e RowId \u5bf9\u8c61<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">\/\/ Initialize a PreparedStatement<br \/>PreparedStatement pstmt = connection.prepareStatement(<br \/>    &quot;SELECT rowid, name, score FROM hellotable WHERE rowid = ?&quot;);<br \/>   \/\/ Bind rowid into prepared statement. <br \/>   pstmt.setRowId(1, rowid);<br \/>   \/\/ Execute the statement<br \/>   ResultSet rset = pstmt.executeQuery();<br \/>   \/\/ List the records<br \/>  while(rs.next()) {<br \/>    RowId id = rs.getRowId(1);<br \/>    \/\/ get the immutable rowid object <br \/>    String name = rs.getString(2);<br \/>    int score = rs.getInt(3);<br \/>  }<\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p>\u9274\u4e8e\u4e0d\u540c DBMS \u7684\u4e0d\u540c\u5b9e\u73b0\uff0cRowID \u5bf9\u8c61\u901a\u5e38\u5728\u4e0d\u540c\u7684\u6570\u636e\u6e90\uff08datasource\uff09\u4e4b\u95f4\u5e76\u4e0d\u662f\u53ef\u79fb\u690d\u7684\u3002\u56e0\u6b64 JDBC 4.0 \u7684 API \u89c4\u8303\u5e76\u4e0d\u5efa\u8bae\u4ece\u8fde\u63a5 A \u53d6\u51fa\u4e00\u4e2a RowID \u5bf9\u8c61\uff0c\u5c06\u5b83\u7528\u5728\u8fde\u63a5 B \u4e2d\uff0c\u4ee5\u907f\u514d\u4e0d\u540c\u7cfb\u7edf\u7684\u5dee\u5f02\u800c\u5e26\u6765\u7684\u96be\u4ee5\u89e3\u91ca\u7684\u9519\u8bef\u3002\u800c\u81f3\u4e8e\u50cf Derby \u8fd9\u6837\u4e0d\u652f\u6301 RowId \u7684 DBMS\uff0c\u7a0b\u5e8f\u5c06\u76f4\u63a5\u5728 setRowId \u65b9\u6cd5\u5904\u629b\u51fa SQLFeatureNotSupportedException\u3002<\/p>\n<p><a name=\"N101E7\"><\/a><span class=\"smalltitle\"><strong><font size=\"3\">SQLXML<\/font><\/strong><\/span><\/p>\n<p>SQL\uff1a2003 \u6807\u51c6\u5f15\u5165\u4e86 SQL\/XML\uff0c\u4f5c\u4e3a SQL \u6807\u51c6\u7684\u6269\u5c55\u3002SQL\/XML \u5b9a\u4e49\u4e86 SQL \u8bed\u8a00\u600e\u6837\u548c XML \u4ea4\u4e92\uff1a\u5982\u4f55\u521b\u5efa XML \u6570\u636e\uff1b\u5982\u4f55\u5728 SQL \u8bed\u53e5\u4e2d\u5d4c\u5165 XQuery \u8868\u8fbe\u5f0f\u7b49\u7b49\u3002\u4f5c\u4e3a JDBC 4.0 \u7684\u4e00\u90e8\u5206\uff0cJava 6 \u589e\u52a0\u4e86 java.sql.SQLXML \u7684\u7c7b\u578b\u3002JDBC \u5e94\u7528\u7a0b\u5e8f\u53ef\u4ee5\u5229\u7528\u8be5\u7c7b\u578b\u521d\u59cb\u5316\u3001\u8bfb\u53d6\u3001\u5b58\u50a8 XML \u6570\u636e\u3002java.sql.Connection.createSQLXML \u65b9\u6cd5\u5c31\u53ef\u4ee5\u521b\u5efa\u4e00\u4e2a\u7a7a\u767d\u7684 SQLXML \u5bf9\u8c61\u3002\u5f53\u83b7\u5f97\u8fd9\u4e2a\u5bf9\u8c61\u4e4b\u540e\uff0c\u4fbf\u53ef\u4ee5\u5229\u7528 setString\u3001setBinaryStream\u3001setCharacterStream \u6216\u8005 setResult \u7b49\u65b9\u6cd5\u6765\u521d\u59cb\u5316\u6240\u8868\u793a\u7684 XML \u6570\u636e\u3002\u4ee5 setCharacterStream \u4e3a\u4f8b\uff0c<a href=\"#list11\"><font color=\"#996699\">\u6e05\u5355 11<\/font><\/a> \u8868\u793a\u4e86\u4e00\u4e2a SQLXML \u5bf9\u8c61\u5982\u4f55\u83b7\u53d6 java.io.Writer \u5bf9\u8c61\uff0c\u4ece\u5916\u90e8\u7684 XML \u6587\u4ef6\u4e2d\u9010\u884c\u8bfb\u53d6\u5185\u5bb9\uff0c\u4ece\u800c\u5b8c\u6210\u521d\u59cb\u5316\u3002<\/p>\n<p><a name=\"list11\"><\/a><strong>\u6e05\u5355 11. \u5229\u7528 setCharacterStream \u65b9\u6cd5\u6765\u521d\u59cb\u5316 SQLXML \u5bf9\u8c61<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">SQLXML xml = con.createSQLXML();<br \/>Writer writer = xml.setCharacterStream();<br \/>BufferedReader reader = new BufferedReader(new FileReader(&quot;test.xml&quot;));<br \/>String line= null;<br \/>while(<br \/>   (line = reader.readLine() != null) {<br \/>      writer.write(line);<br \/>   } <\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p>\u7531\u4e8e SQLXML \u5bf9\u8c61\u6709\u53ef\u80fd\u4e0e\u5404\u79cd\u5916\u90e8\u7684\u8d44\u6e90\u6709\u8054\u7cfb\uff0c\u5e76\u4e14\u5728\u4e00\u4e2a\u4e8b\u52a1\u4e2d\u4e00\u76f4\u6301\u6709\u8fd9\u4e9b\u8d44\u6e90\u3002\u4e3a\u4e86\u9632\u6b62\u5e94\u7528\u7a0b\u5e8f\u8017\u5c3d\u8d44\u6e90\uff0cJava 6 \u63d0\u4f9b\u4e86 free \u65b9\u6cd5\u6765\u91ca\u653e\u5176\u8d44\u6e90\u3002\u7c7b\u4f3c\u7684\u8bbe\u8ba1\u5728 java.sql.Array\u3001Clob \u4e2d\u90fd\u6709\u51fa\u73b0\u3002<\/p>\n<p>\u81f3\u4e8e\u5982\u4f55\u4f7f\u7528 SQLXML \u4e0e\u6570\u636e\u5e93\u8fdb\u884c\u4ea4\u4e92\uff0c\u5176\u65b9\u6cd5\u4e0e\u5176\u5b83\u7684\u7c7b\u578b\u90fd\u5341\u5206\u76f8\u4f3c\u3002\u53ef\u4ee5\u53c2\u7167 <a href=\"#rowid\"><font color=\"#996699\">RowId \u4e00\u8282<\/font><\/a> \u4e2d\u7684\u4f8b\u5b50\u5728 Java SE 6 \u7684 API \u89c4\u8303\u4e2d\u627e\u5230 SQLXML \u4e2d\u5bf9\u5e94\u7684 get\/set\/update \u65b9\u6cd5\u6784\u5efa\u7c7b\u4f3c\u7684\u7a0b\u5e8f\uff0c\u6b64\u5904\u4e0d\u518d\u8d58\u8ff0\u3002<\/p>\n<p><a name=\"N1022E\"><\/a><span class=\"smalltitle\"><strong><font size=\"3\">SQLExcpetion \u7684\u589e\u5f3a<\/font><\/strong><\/span><\/p>\n<p>\u5728 Java SE 6 \u4e4b\u524d\uff0c\u6709\u5173 JDBC \u7684\u5f02\u5e38\u7c7b\u578b\u4e0d\u8d85\u8fc7 10 \u4e2a\u3002\u8fd9\u4f3c\u4e4e\u5df2\u7ecf\u4e0d\u8db3\u4ee5\u63cf\u8ff0\u65e5\u6e10\u590d\u6742\u7684\u6570\u636e\u5e93\u5f02\u5e38\u60c5\u51b5\u3002\u56e0\u6b64\uff0cJava SE 6 \u7684\u8bbe\u8ba1\u4eba\u5458\u5bf9\u4ee5 java.sql.SQLException \u4e3a\u6839\u7684\u5f02\u5e38\u4f53\u7cfb\u4f5c\u4e86\u5927\u5e45\u5ea6\u7684\u6539\u8fdb\u3002\u9996\u5148\uff0cSQLException \u65b0\u5b9e\u73b0\u4e86 Iterable&lt;Throwable&gt; \u63a5\u53e3\u3002<a href=\"#list12\"><font color=\"#996699\">\u6e05\u5355 12<\/font><\/a> \u5b9e\u73b0\u4e86 <a href=\"#list1\"><font color=\"#996699\">\u6e05\u5355 1<\/font><\/a> \u7a0b\u5e8f\u7684\u5f02\u5e38\u5904\u7406\u673a\u5236\u3002\u8fd9\u6837\u7b80\u6d01\u5730\u904d\u5386\u4e86\u6bcf\u4e00\u4e2a SQLException \u548c\u5b83\u6f5c\u5728\u7684\u539f\u56e0\uff08cause\uff09\u3002<\/p>\n<p><a name=\"list12\"><\/a><strong>\u6e05\u5355 12. SQLException \u7684 for-each loop<\/strong><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td class=\"code-outline\">\n<pre class=\"displaycode\">\/\/ Java 6 code<br \/>catch (Throwable e) {<br \/>   if (e instanceof SQLException) {<br \/>       for(Throwable ex : (SQLException)e ){<br \/>            System.err.println(ex.toString());<br \/>        }<br \/>    }<br \/>} <\/pre>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><\/p>\n<p>\u6b64\u5916\uff0c<a href=\"#fig004\"><font color=\"#996699\">\u56fe 4<\/font><\/a> \u8868\u793a\u4e86\u5168\u90e8\u7684 SQLException \u5f02\u5e38\u4f53\u7cfb\u3002\u9664\u53bb\u539f\u6709\u7684 SQLException \u7684\u5b50\u7c7b\uff0cJava 6 \u4e2d\u65b0\u589e\u7684\u5f02\u5e38\u7c7b\u88ab\u5206\u4e3a 3 \u79cd\uff1aSQLReoverableException\u3001SQLNonTransientException\u3001SQLTransientException\u3002\u5728 SQLNonTransientException \u548c SQLTransientException \u4e4b\u4e0b\u8fd8\u6709\u82e5\u5e72\u5b50\u7c7b\uff0c\u8be6\u7ec6\u5730\u533a\u5206\u4e86 JDBC \u7a0b\u5e8f\u4e2d\u53ef\u80fd\u51fa\u73b0\u7684\u5404\u79cd\u9519\u8bef\u60c5\u51b5\u3002\u5927\u591a\u6570\u5b50\u7c7b\u90fd\u4f1a\u6709\u5bf9\u5e94\u7684\u6807\u51c6 SQLState \u503c\uff0c\u5f88\u597d\u5730\u5c06 SQL \u6807\u51c6\u548c Java 6 \u7c7b\u5e93\u7ed3\u5408\u5728\u4e00\u8d77\u3002<\/p>\n<p><a name=\"fig004\"><\/a><strong>\u56fe 4. SQLException \u5f02\u5e38\u4f53\u7cfb<\/strong><br \/><img decoding=\"async\" src=\"http:\/\/www.ibm.com\/developerworks\/cn\/java\/j-lo-jse65\/fig004.gif\" alt=\"\u56fe 4. SQLException \u5f02\u5e38\u4f53\u7cfb\" \/> <\/p>\n<p>\u5728\u4f17\u591a\u7684\u5f02\u5e38\u7c7b\u4e2d\uff0c\u6bd4\u8f83\u5e38\u89c1\u7684\u6709 SQLFeatureNotSupportedException\uff0c\u7528\u6765\u8868\u793a JDBC \u9a71\u52a8\u4e0d\u652f\u6301\u67d0\u9879 JDBC \u7684\u7279\u6027\u3002\u4f8b\u5982\u5728 Derby \u4e0b\u8fd0\u884c <a href=\"#list10\"><font color=\"#996699\">\u6e05\u5355 10<\/font><\/a> \u4e2d\u7684\u7a0b\u5e8f\uff0c\u5c31\u53ef\u4ee5\u53d1\u73b0 Derby \u7684\u9a71\u52a8\u5e76\u4e0d\u652f\u6301 RowId \u7684\u7279\u6027\u3002\u53e6\u5916\u503c\u5f97\u4e00\u63d0\u7684\u662f\uff0cSQLClientInfoException \u76f4\u63a5\u7ee7\u627f\u81ea SQLException\uff0c\u8868\u793a\u5f53\u4e00\u4e9b\u5ba2\u6237\u7aef\u7684\u5c5e\u6027\u4e0d\u80fd\u88ab\u8bbe\u7f6e\u5728\u4e00\u4e2a\u6570\u636e\u5e93\u8fde\u63a5\u65f6\u6240\u53d1\u751f\u7684\u5f02\u5e38\u3002<\/p>\n<p><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" width=\"100%\">\n<tbody>\n<tr>\n<td><img decoding=\"async\" src=\"http:\/\/www.ibm.com\/i\/v14\/rules\/blue_rule.gif\" alt=\"\" width=\"100%\" height=\"1\" \/><br \/><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/www.ibm.com\/i\/c.gif\" border=\"0\" alt=\"\" width=\"8\" height=\"6\" \/><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\" class=\"no-print\" align=\"right\">\n<tbody>\n<tr align=\"right\">\n<td><img decoding=\"async\" src=\"http:\/\/www.ibm.com\/i\/c.gif\" alt=\"\" width=\"100%\" height=\"4\" \/><\/p>\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td valign=\"middle\"><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/www.ibm.com\/i\/v14\/icons\/u_bold.gif\" border=\"0\" alt=\"\" width=\"16\" height=\"16\" \/><\/td>\n<td align=\"right\" valign=\"top\"><a href=\"#main\"><strong><font color=\"#996699\">\u56de\u9875\u9996<\/font><\/strong><\/a><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><a name=\"N10289\"><\/a><span class=\"atitle\">\u5c0f\u7ed3\uff1a\u66f4\u591a\u65b0\u7279\u6027\u4e0e\u5c55\u671b<\/span><\/p>\n<p>\u5728\u672c\u6587\u4e2d\uff0c\u6211\u4eec\u5df2\u7ecf\u5411\u8bfb\u8005\u4ecb\u7ecd\u4e86 Java SE 6 \u4e2d JDBC \u6700\u91cd\u8981\u7684\u4e00\u4e9b\u65b0\u7279\u6027\uff1a\u5b83\u4eec\u5305\u62ec\u5d4c\u5728 JDK \u4e2d\u7684 Java DB \uff08Derby\uff09\u548c JDBC 4.0 \u7684\u4e00\u90e8\u5206\u3002\u5f53\u7136\uff0c\u8fd8\u6709\u5f88\u591a\u672c\u6587\u8fd8\u6ca1\u6709\u8986\u76d6\u5230\u7684\u65b0\u7279\u6027\u3002\u6bd4\u5982\u589e\u52a0\u4e86\u5bf9 SQL \u8bed\u8a00\u4e2d NCHAR\u3001NVARCHAR\u3001LONGNVARCHAR \u548c NCLOB \u7c7b\u578b\u7684\u652f\u6301\uff1b\u5728\u6570\u636e\u5e93\u8fde\u63a5\u6c60\u7684\u73af\u5883\u4e0b\u4e3a\u7ba1\u7406 Statement \u5bf9\u8c61\u63d0\u4f9b\u66f4\u591a\u7075\u6d3b\u3001\u4fbf\u5229\u7684\u65b9\u6cd5\u7b49\u3002<\/p>\n<p>\u6b64\u5916\uff0c\u5728 Java SE 6 \u7684 beta \u7248\u4e2d\uff0c\u66fe\u7ecf\u5c06 Annotation Query \u7684\u7279\u6027\u5305\u542b\u8fdb\u6765\u3002\u8fd9\u9879\u7279\u6027\u5b9a\u4e49\u4e86\u4e00\u7cfb\u5217 Query \u548c DataSet \u63a5\u53e3\uff0c\u7a0b\u5e8f\u5458\u53ef\u4ee5\u901a\u8fc7\u64b0\u5199\u4e00\u4e9b Annotation \u6765\u81ea\u5b9a\u4e49\u67e5\u8be2\u5e76\u83b7\u5f97\u5b9a\u5236\u7684\u6570\u636e\u96c6\u7ed3\u679c\u3002\u4f46\u662f\uff0c\u7531\u4e8e\u8fd9\u4e00\u7279\u6027\u7684\u53c2\u8003\u5b9e\u73b0\u6700\u7ec8\u4e0d\u80fd\u6ee1\u8db3 JDK \u7684\u8d28\u91cf\u9700\u6c42\uff0cSun \u516c\u53f8\u5fcd\u75db\u5272\u7231\uff0c\u53d6\u6d88\u4e86\u5728 Java SE 6 \u4e2d\u53d1\u5e03\u5176\u7684\u8ba1\u5212\u3002\u6211\u4eec\u6709\u7406\u7531\u76f8\u4fe1\uff0c\u5728\u4ee5\u540e\u7684 JDK \u7248\u672c\u4e2d\uff0c\u8fd9\u4e00\u7279\u6027\u4ee5\u53ca\u66f4\u591a\u65b0\u7684\u529f\u80fd\u5c06\u88ab\u5305\u542b\u8fdb\u6765\uff0c\u5229\u7528 Java \u8bed\u8a00\u6784\u5efa\u6570\u636e\u5e93\u7684\u5e94\u7528\u4e5f\u4f1a\u53d8\u5f97\u66f4\u4e3a\u81ea\u7136\u3001\u987a\u7545\u3002<\/p>\n<p><a name=\"resources\"><\/a><span class=\"atitle\">\u53c2\u8003\u8d44\u6599 <\/span><\/p>\n<ul>\n<li>\u9605\u8bfb <a href=\"http:\/\/www.ibm.com\/developerworks\/cn\/java\/j-lo-jse6\/\"><font color=\"#5c81a7\"><em>Java SE 6 \u65b0\u7279\u6027\u7cfb\u5217<\/em> <\/font><\/a>\u6587\u7ae0\u7684\u5b8c\u6574\u5217\u8868\uff0c\u4e86\u89e3 Java SE 6 \u5176\u5b83\u91cd\u8981\u7684\u589e\u5f3a\u3002\n<\/li>\n<li><a href=\"http:\/\/java.sun.com\/javase\/6\/docs\/\"><font color=\"#5c81a7\">Java SE 6 \u6587\u6863<\/font><\/a>\uff1aJava SE 6 \u7684\u89c4\u8303\u6587\u6863\uff0c\u53ef\u4ee5\u627e\u5230\u7edd\u5927\u90e8\u5206\u65b0\u7279\u6027\u7684\u5b98\u65b9\u8bf4\u660e\u3002\n<\/li>\n<li>\u53c2\u8003 Sun \u516c\u53f8 Java SE 6 \u5173\u4e8e JDBC \u7684 API \u53c2\u8003\u6587\u6863\uff1a<a href=\"http:\/\/java.sun.com\/javase\/6\/docs\/api\/java\/sql\/package-summary.html\"><font color=\"#5c81a7\">java.sql<\/font><\/a> \u548c <a href=\"http:\/\/java.sun.com\/javase\/6\/docs\/api\/javax\/sql\/package-summary.html\"><font color=\"#5c81a7\">javax.sql<\/font><\/a>\u3002\n<\/li>\n<li>developerWorks <a href=\"http:\/\/www.ibm.com\/developerworks\/cn\/opensource\/top-projects\/derby.html\"><font color=\"#5c81a7\">Apache Derby \u9879\u76ee\u8d44\u6e90\u4e2d\u5fc3<\/font><\/a>\uff1a\u66f4\u591a\u5173\u4e8e Apache Derby \u9879\u76ee\u7684\u6280\u672f\u6587\u7ae0\u548c\u6559\u7a0b \u3002\n<\/li>\n<li><a href=\"http:\/\/developers.sun.com\/javadb\/\"><font color=\"#5c81a7\">Java DB at a Glance<\/font><\/a>\uff1a\u5173\u4e8e Java DB \u7684\u4ecb\u7ecd\u3002\n<\/li>\n<li><a href=\"http:\/\/db.apache.org\/derby\/quick_start.html\"><font color=\"#5c81a7\">Apache Derby: Quick Start<\/font><\/a>\uff1aApache Derby \u7684\u5feb\u901f\u5165\u95e8\u624b\u518c\u3002\n<\/li>\n<li>\u53c2\u8003 <a href=\"http:\/\/jcp.org\/en\/jsr\/detail?id=221\"><font color=\"#5c81a7\">JDBC 4.0 API \u89c4\u8303<\/font><\/a>\u3002<\/li>\n<\/ul>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>2006 \u5e74\u5e95\uff0cSun \u516c\u53f8\u53d1\u5e03\u4e86 Java Standard Edition 6\uff08Java SE 6\uff09\u7684\u6700\u7ec8\u6b63\u5f0f\u7248\uff0c\u4ee3\u53f7 Mustang\uff08\u91ce\u9a6c\uff09\u3002\u8ddf Tiger\uff08Java SE 5\uff09\u76f8\u6bd4\uff0cMustang \u5728\u6027\u80fd\u65b9\u9762\u6709\u4e86\u4e0d\u9519\u7684\u63d0\u5347\u3002\u4e0e Tiger \u5728 API \u5e93\u65b9\u9762\u7684\u5927\u5e45\u5ea6\u52a0\u5f3a\u76f8\u6bd4\uff0c\u867d\u7136 Mustang \u5728 API \u5e93\u65b9\u9762\u7684\u65b0\u7279\u6027\u663e\u5f97\u4e0d\u592a\u591a\uff0c\u4f46\u662f\u4e5f\u63d0\u4f9b\u4e86\u8bb8\u591a\u5b9e\u7528\u548c\u65b9\u4fbf\u7684\u529f\u80fd\uff1a\u5728\u811a\u672c\uff0cWebService\uff0cXML\uff0c\u7f16\u8bd1\u5668 API\uff0c\u6570\u636e\u5e93\uff0cJMX\uff0c\u7f51\u7edc\u548c Instrumentation \u65b9\u9762\u90fd\u6709\u4e0d\u9519\u7684\u65b0\u7279\u6027\u548c\u529f\u80fd\u52a0\u5f3a\u3002 \u672c\u7cfb\u5217 \u6587\u7ae0\u4e3b\u8981\u4ecb\u7ecd Java SE 6 \u5728 API \u5e93\u65b9\u9762\u7684\u90e8\u5206\u65b0\u7279\u6027\uff0c\u901a\u8fc7\u4e00\u4e9b\u4f8b\u5b50\u548c\u8bb2\u89e3\uff0c\u5e2e\u52a9\u5f00\u53d1\u8005\u5728\u7f16\u7a0b\u5b9e\u8df5\u5f53\u4e2d\u66f4\u597d\u7684\u8fd0\u7528 Java SE 6\uff0c\u63d0\u9ad8\u5f00\u53d1\u6548\u7387\u3002 \u672c\u6587\u662f\u7cfb\u5217\u6587\u7ae0\u7684\u7b2c 5 \u7bc7\uff0c\u4ecb\u7ecd\u4e86 Java SE 6 \u5728\u6570\u636e\u5e93\u7f16\u7a0b\u65b9\u9762\u7684\u65b0\u7279\u6027\u3002 \u957f\u4e45\u4ee5\u6765\uff0c\u7531\u4e8e\u5927\u91cf\uff08\u751a\u81f3\u51e0\u4e4e\u6240\u6709\uff09\u7684 Java \u5e94\u7528\u90fd\u4f9d\u8d56\u4e8e\u6570\u636e\u5e93\uff0c\u5982\u4f55\u4f7f\u7528 Java \u8bed\u8a00\u9ad8\u6548\u3001\u53ef\u9760\u3001\u7b80\u6d01\u5730\u8bbf\u95ee\u6570\u636e\u5e93\u4e00\u76f4\u662f\u7a0b\u5e8f\u5458\u4eec\u6d25\u6d25\u4e50\u9053\u7684\u8bdd\u9898\u3002\u65b0\u53d1\u5e03\u7684 Java SE 6 \u4e5f\u5728\u8fd9\u65b9\u9762\u66f4\u4e0a\u5c42\u697c\uff0c\u4e3a\u7f16\u7a0b\u4eba\u5458\u63d0\u4f9b\u4e86\u8bb8\u591a\u597d\u7528\u7684\u65b0\u7279\u6027\u3002\u5176\u4e2d\u6700\u663e\u8457\u7684\uff0c\u83ab\u8fc7\u4e8e Java SE 6 &hellip; <a href=\"https:\/\/www.strongd.net\/?p=208\" class=\"more-link\">Continue reading <span class=\"screen-reader-text\">Java SE 6 \u65b0\u7279\u6027: Java DB \u548c JDBC 4.0<\/span><\/a><\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-208","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/www.strongd.net\/index.php?rest_route=\/wp\/v2\/posts\/208","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.strongd.net\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.strongd.net\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.strongd.net\/index.php?rest_route=\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.strongd.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=208"}],"version-history":[{"count":0,"href":"https:\/\/www.strongd.net\/index.php?rest_route=\/wp\/v2\/posts\/208\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.strongd.net\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=208"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.strongd.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=208"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.strongd.net\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=208"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}