dbf文件操作方案介绍

     .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/


你可能感兴趣的:(javaDBF,dbf)