derby本地访问

偶然某个程序需要使用到derby数据库,以前完全没有用过。熟悉的过程中发现网上的代码跑不通,研究了一下,记录如下

先贴一个网上的代码:来自http://www.blogjava.net/moshangchen/articles/210695.html

import java.sql.SQLException;
/**
 * 第一个 JDBC 的 HelloWorld 程序, 数据库访问 MySQL.
 * @author BeanSoft@126.com
 * @version 0.3 2007-12-12
 */
public class JDBCHelloWorld {
    public static void main(String[] args) {
        // 1. 注册驱动
        try {
            Class.forName("org.apache.derby.jdbc.ClientDriver");
        } catch (ClassNotFoundException e) {
           // TODO Auto-generated catch block
           e.printStackTrace();
       }
       ......
       try {
           // 2. 获取数据库的连接
           conn = java.sql.DriverManager.getConnection(
                   "jdbc:derby://localhost:1527/myeclipse",
"classiccars", "classiccars");
 // 3. 获取表达式
           stmt = conn.createStatement();
                   // 执行插入数据的 SQL
           stmt.executeUpdate("insert into Student(username, password,age) values('张三', '1234', 20)");
           // 4. 执行 SQL
           rs = stmt.executeQuery("select * from Student");
           // 5. 显示结果集里面的数据
           while(rs.next()) {
               System.out.println("编号=" + rs.getInt(1));
               System.out.println("学生姓名=" +
                       rs.getString("username"));
                                      System.out.println("密码=" + rs.getString("password"));
                                      System.out.println("年龄=" + rs.getString("age"));
                                  }
           // 执行删除数据的 SQL
          // stmt.executeUpdate("delete from Student");
                              } catch (SQLException e) {
                                  e.printStackTrace();
                              } finally {
                                 // 6. 释放资源,建议放在finally语句中确保都被关闭掉了
                                 try {
                                     rs.close();
                                 } catch (SQLException e) {
                                 }
                                 try {
                                     stmt.close();
                                 } catch (SQLException e) {
                                 }
                                 try {
                                     conn.close();
                                 } catch (SQLException e) {
                                 }
                              }
                          }
                       }

跑不通,总是出现拒绝连接,后来发现有个EmbededDriver,根据名字看似乎本机访问应该用这个,加载驱动的语句改为

Class.forName("org.apache.derby.jdbc.EmbededDriver");
数据库连接的url也要修改:
conn = java.sql.DriverManager.getConnection("jdbc:derby:%databaselocation%","username", "password");
我的databaselocation是c:/usrs/administrator/db/数据库名字,这个似乎是derby默认存储的位置。
前面的代码应该也是能够跑通的,可能是derby的模式问题或者别的设置什么的,暂时还没有发现原因。端口也没有被占用。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值