.dbf是dBASE数据库中存储数据的文件格式,同时也可被xBASE系列的数据库识别。实际的项目中存在同时使用dBASE和oracle数据库的问题,这两类数据库间存在数据数据交互的问题,有时候需要从dbf中导入数据,有时候需要导入数据到dbf文件中。下面主要介绍在java语言中怎么读和写dbf,同时介绍一个工具方便的查看dbf文件中的数据。
关于DBF文件内容的查看
利用工具http://www.alexnolan.net/software/dbf.htm,可以对dbf中的数据进行查询,导入,导出。支持dBASE,Clipper,和FoxPro数据库。具体的使用,比较简单请查看网页上的说明。
关于DBF文件内容的读写
java中能够读、写dbf内容的方式很多,包括JavaDBF、ExDBF、Caigen DBF等,从代码简单、实用、代码开源且简单这些角度考虑,个人推荐使用JavaDBF来操作dbf文件,下面分别给出读和写的列子:
读dbf文件
package com.excellence.dbf.javadbf;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import com.linuxense.javadbf.DBFException;
import com.linuxense.javadbf.DBFField;
import com.linuxense.javadbf.DBFReader;
public class JavaDBFReaderTest {
public static void main(String args[]) {
try {
InputStream inputStream = new FileInputStream("E:\\users\\pengsy\\DBF\\test\\javadbf.dbf");
DBFReader reader = new DBFReader(inputStream);
reader.setCharactersetName("gbk");
int numberOfFields = reader.getFieldCount();
for (int i = 0; i < numberOfFields; i++) {
DBFField field = reader.getField(i);
System.out.print(field.getName()+"\t");
}
System.out.println();
Object[] rowObjects;
while ((rowObjects = reader.nextRecord()) != null) {
for (int i = 0; i < rowObjects.length; i++) {
System.out.print(rowObjects[i].toString().trim()+"\t\t");
}
System.out.println();
}
inputStream.close();
} catch (DBFException e) {
System.out.println(e.getMessage());
} catch (IOException e) {
System.out.println(e.getMessage());
}
}
}
写dbf
package com.excellence.dbf.javadbf;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import com.linuxense.javadbf.DBFException;
import com.linuxense.javadbf.DBFField;
import com.linuxense.javadbf.DBFWriter;
public class DBFWriterTest {
public static void main(String args[]) throws DBFException, IOException {
DBFField fields[] = new DBFField[3];
fields[0] = new DBFField();
fields[0].setName("emp_code");
fields[0].setDataType(DBFField.FIELD_TYPE_C);
fields[0].setFieldLength(10);
fields[1] = new DBFField();
fields[1].setName("emp_name");
fields[1].setDataType(DBFField.FIELD_TYPE_C);
fields[1].setFieldLength(20);
fields[2] = new DBFField();
fields[2].setName("salary");
fields[2].setDataType(DBFField.FIELD_TYPE_N);
fields[2].setFieldLength(12);
fields[2].setDecimalCount(2);
DBFWriter writer = new DBFWriter();
writer.setFields(fields);
Object rowData[] = new Object[3];
rowData[0] = "1000";
rowData[1] = "John";
rowData[2] = new Double(5000.00);
writer.addRecord(rowData);
rowData = new Object[3];
rowData[0] = "1001";
rowData[1] = "Lalit";
rowData[2] = new Double(3400.00);
writer.addRecord(rowData);
rowData = new Object[3];
rowData[0] = "1002";
rowData[1] = "Rohit";
rowData[2] = new Double(7350.00);
writer.addRecord(rowData);
File file = new File("E:\\users\\pengsy\\DBF\\test\\javadbf.dbf");
FileOutputStream fos = new FileOutputStream(file);
writer.write(fos);
fos.close();
}
}
这里只演示了基于JavaDBF对dbf简单的读写操作,实际上使用的时候还要考虑列名的映射问题。
对JavaDBF有更多的了解请参考http://javadbf.sarovar.org/