首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 计算机考试 > 认证考试 > JAVA认证 >

java动态创建ODBC数据源来访问DBF文件

2008-11-14 
创建ODBC数据源来访问DBF文件的方法

    想了两种解决方法,第一种比较麻烦,其实就是通过java动态创建ODBC数据源来访问DBF文件,这个就需要用到registry,来修改注册表了。
  其实,主要是动态创建ODBC数据源,开始很简单,可以手工设置一次数据源,当然也可以通过程序直接生成,问题都不大。下面只说怎样修改。
  import com.ice.jni.registry.RegStringValue;
   import com.ice.jni.registry.Registry;
   import com.ice.jni.registry.RegistryKey;
  public class TestC {
   public static void main(String[] str) {
   try {
   RegistryKey child = Registry.HKEY_CURRENT_USER
   .openSubKey("Software").openSubKey("ODBC").openSubKey
   ("ODBC.INI").openSubKey("data_0930",RegistryKey.ACCESS_ALL);//
   操作权限是通过RegistryKey来获取的。
   String de = "F:\\commony\\test\\data\\070901"; //
   我的DBF数据的目录//其中,data_0930是我第一次设置的数据源的一个注册表的名称
   System.out.println(child.getStringValue("SourceDB"));
   child.setValue(new RegStringValue(child,"SourceDB",de));
   System.out.println(child.getFullName());
   } catch (Exception e) {
   e.printStackTrace();
   }
   }
  }
然后就是通过,sun.jdbc.odbc.JdbcOdbcDriver来获取数据,
  import java.sql.DriverManager;
   import java.sql.*;
   public class TestOdbc {
   public TestOdbc() {
   }
   public static void main(String[] args) {
   java.sql.Connection conn = null;
   java.sql.PreparedStatement pt = null;
   java.sql.ResultSet rs = null;
   try {
   Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
   }
   catch (ClassNotFoundException ex1) {
   }
   try {
   conn = DriverManager.getConnection("jdbc:odbc:data_0930", "", "");
   pt = conn.prepareStatement(" select * from test_table");
   rs = pt.executeQuery();
   while(rs.next()){
   System.out.println("==="+rs.getString(1));
   System.out.println("==="+rs.getString(2));
   System.out.println("==="+rs.getString(3));
   System.out.println("==="+rs.getString(4));
   System.out.println("==="+rs.getString(5));
   }
   }
   catch (SQLException ex) {
   }
   }
   }
其实真的很简单。
  其实,文件名,是可以动态获取的,一般可以通过java中的File类来获取:
  import java.io.File;
  public class TestD {
   public static void main(String[] args){
   File file = new File("F:\\commony\\test\\data");
   File[] df = file.listFiles();
   for(int k =0;k if(df[k].isDirectory()){ //
   因为文件夹中包含DBF文件,所以判断是文件夹,而不是文件
   System.out.println("===kkkk=="+k+"====="+df[k].getName());
   }
   }
   }
   }
  第一种就是这样,需要注意的是registry的使用,其实很简单的,只要把DLL文件放到classpath下就可以了。
  第二种其实更简单,就是通过另一个开元的类包jdbf.jar,使用方法也很简单,网上有很多资料,可以查询。

3COME考试频道为您精心整理,希望对您有所帮助,更多信息在http://www.reader8.com/exam/

热点排行