Ryan's Java world!

          something about Java and opensource!

          BlogJava 首頁 新隨筆 聯(lián)系 聚合 管理
            51 Posts :: 25 Stories :: 59 Comments :: 0 Trackbacks

          在前面兩篇 http://blog.matrix.org.cn/comments/icess/Weblog/use_derby_with_clob_and??文章中,我簡單介紹了如何使用Java DB操作數(shù)據(jù),今天發(fā)現(xiàn)一個(gè)關(guān)于關(guān)閉數(shù)據(jù)庫的問題, 就是在調(diào)用前面例子中的關(guān)閉數(shù)據(jù)庫代碼時(shí)候總是拋出異常 ,后來到文檔里面看看 ,原來在關(guān)閉數(shù)據(jù)庫時(shí)候, Derby總是拋出異常,我還以為是我那個(gè)地方寫錯(cuò)了呢?

          以前例子中沒有顯示異常信息 是應(yīng)為 在關(guān)閉數(shù)據(jù)庫的方法中沒有使用 打印異常信息的語句, 如下

          public void disconnect() {
          ??????? if(isConnected) {
          ??????????? String dbUrl = getDatabaseUrl();
          ??????????? dbProperties.put("shutdown", "true");
          ??????????? try {
          ??????????????? DriverManager.getConnection(dbUrl, dbProperties);
          ??????????? } catch (SQLException ex) {
          ??????????? ?//ex.printStackTrace();?? //?前面的例子沒有該句, 如果加上該句,就會看的異常信息
          ??????????? }
          ??????????? isConnected = false;
          ??????? }
          ??? }

          ?

          所以,當(dāng)大家看到下面的異常時(shí)候,不用擔(dān)心 不是你的代碼寫錯(cuò)了,而是程序正確關(guān)閉數(shù)據(jù)庫的提示(有點(diǎn)違背異常的設(shè)計(jì)初衷哦).

          ERROR 08006: Database 'TestClob' shutdown.
          ?at org.apache.derby.iapi.error.StandardException.newException(Unknown Source)
          ?at org.apache.derby.impl.jdbc.TransactionResourceImpl.shutdownDatabaseException(Unknown Source)
          ?at org.apache.derby.impl.jdbc.EmbedConnection.<init>(Unknown Source)

          ...........
          21:10 補(bǔ)充:

          使用Java DB的最佳實(shí)踐

          Recommended practices

          When developing Derby applications, create a single directory to hold your database or databases. Give this directory a unique name, to help you remember that:
          • All databases exist within a system.
          • System-wide properties affect the entire system, and persistent system-wide properties live in the system directory.
          • You can boot all the databases in the system, and the boot-up times of all databases affect the performance of the system.
          • You can preboot databases only if they are within the system. (Databases do not necessarily have to live inside the system directory, but keeping your databases there is the recommended practice.)
          • Once you connect to a database, it is part of the current system and thus inherits all system-wide properties.
          • Only one instance of Derby can run in a JVM at a single time, and only one instance of Derby should boot a database at one time. Keeping databases in the system directory makes it less likely that you would use more than one instance of Derby.
          • The error log is located inside the system directory.
          posted on 2006-04-17 20:38 冰雨 閱讀(855) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           

          JSF中文技術(shù)文摘
          主站蜘蛛池模板: 金川县| 霍邱县| 富顺县| 佳木斯市| 武夷山市| 兴隆县| 大城县| 施秉县| 江华| 五峰| 河曲县| 木兰县| 宿迁市| 方正县| 东乌珠穆沁旗| 泌阳县| 神木县| 阿拉尔市| 孝义市| 岗巴县| 金溪县| 泰顺县| 加查县| 龙岩市| 缙云县| 巫溪县| 北宁市| 九台市| 汶川县| 永善县| 临朐县| 张家界市| 微山县| 大连市| 淳化县| 石屏县| 瓦房店市| 奎屯市| 黄梅县| 博爱县| 司法|