zoukankan      html  css  js  c++  java
  • java远程连接access数据库

    本文转载自http://www.voidcn.com/article/p-tlrtkqlp-k.html

    1  rmijdbc远程连接access数据库

    正常情况下,常用的数据库sql server, oracle,mysql等(曾经有同学居然说除了sql server和oracle就没有DBMS了。。。天。。。),做为一个服务在服务器上跑,java需要远程连接的时候使用jdbc非常方便。可是有的时候,也就是在一些非常特殊的情况下,使用sql server, oracle等数据库有点大炮打蚊子的感觉,这时候从问题规模上说,使用access是比较合理的,但是有需要远程访问这么办。
       如果使用vc等工具,这也不是难题,使用ado不是很困难,但是使用java怎么办。。。
       有人说是用odbc数据源,是的,但是odbc数据源怎么远程访问(使用java),网上有人这样写
       jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=//192.168.0.1/目录/db.mdb";
       简直是胡说八道,如果没有使用特别的手段(比如服务器路径映射等等。。我没有试过,反正直接这样写实不行的,这个我试过)。
       那么有什么办法能够远程连接access数据库呢,使用rmijdbc( http://rmijdbc.objectweb.org)

    ,简单说一下怎么用。
       1 首先下载rmijdbc.jar, 加入系统环境变量,
      使你的CLASSPATH变量指向RmiJdbc.jar包:它位于RmiJdbc的dist/lib子目录
    • Unix example (bash style):
      export CLASSPATH=$CLASSPATH:/usr/local/RmiJdbc/dist/lib/RmiJdbc.jar
    • Windows example:
      set CLASSPATH=%CLASSPATH%;D:RmiJdbcdistlibRmiJdbc.jar
       2  接着,运行 java org.objectweb.rmijdbc.RJJdbcServer(这一步很重要,是启动rmijdbc服务,否则连接的时候报Connection refuse异常)。
     在32位的jdk环境下安装成功
        

      在64位的jdk环境下安装报错了

        

       3   剩下的当然就是怎么连接了。

       第一步:在服务器上建一个odbc数据源,指向一个.mdb文件
       第二步:客户端连接代码
                   Class.forName("org.objectweb.rmijdbc.Driver").newInstance();
                   String url = "jdbc:rmi://192.168.0.201/jdbc:odbc:english";
      明白了吧,很简单。
      这样,当规模不大的时候,我们就不需要安装Sql server 这些比较重量级的家伙了,采用access轻便又实用。
     
    参考帖子:
    http://blog.csdn.net/hongdi/article/details/5482470(该帖验证步骤是正确的)
     
     
    另一种方法:

    2 java 使用 ucanaccess 连接Access数据库

    转载地址

    package com.xu.access;

    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.Statement;

    //首先需要添加 ucanaccess 的jar包
    //ucanaccess下载–>(http://download.csdn.net/detail/qq_34814092/9852513)
    //ucanaccess官网–>(https://sourceforge.net/projects/ucanaccess/)
    //然后引入 ucanaccess 的 jar 包
    //可以只引入核心 ucanaccess 的 jar 包,建议全部引入

    public class Access {
    public static void main(String[] args) throws Exception {
    //———————————————————————————————
    Class.forName(“net.ucanaccess.jdbc.UcanaccessDriver”);//这个驱动的地址不要改
    Connection con=DriverManager.getConnection(“jdbc:ucanaccess://G:Accessookmng.mdb”,”“,”“);
    //DriverManager.getConnection(“jdbc:ucanaccess://G:Accessookmng.mdb”,”“,”“);
    //只依据自己的实际情况更改 G:Accessookmng.mdb 即你的Access文件(如text.mdb) 的绝对路径或相对路径
    //后面的两个参数可以不用填写
    //除了上面的两步下面的操作和 MySQL Oracle 的基本一样
    Statement stmt=con.createStatement();
    //———————————————————————————————
    //查找数据
    ResultSet rs=stmt.executeQuery(“select * from test”);
    while(rs.next()){
    System.out.println(rs.getString(“name”));
    }

  • 相关阅读:
    HTTPD之五---HTTP协议、相关工具及状态码
    HTTPD之四----实现HTTPD正向代理与反向代理
    第十三周---DNS原理、实现智能DNS及源码编译mariadb数据库
    DNS之五----实现智能DNS
    sqoop 导入增量数据到hive
    Hadoop 二次排序
    Spark foreachpartiton和mappartition的异同
    hadoop 实现多文件输出
    spark 实现多文件输出
    Scala 中 call by name & call by value 的区别
  • 原文地址:https://www.cnblogs.com/abc8023/p/7831194.html
Copyright © 2011-2022 走看看