.NET读取dbf的方式,C#读取foxpro数据库

  • Post author:
  • Post category:其他


.NET读取dbf的方式,C#读取foxpro数据库

下面使用

C#

来读取foxpro

数据库

前些天就遇到一个将dbf数据文件读取到datagridview里,然后再导入到

SQL

Server数据库里,难点就是如何将dbf文件读取到dataset或datatable里。
下面是其中的一个方法,就是利用OleDb类来读取,在一些客户的电脑上可能没有读取dbf的组件,这里需要安装一个文件“VFPOLEDBSetup.msi”,这个可以到网上搜索,一堆,也可以到微软官方去下载。代码如下:
        string filePath = textBox2.Text; //文件路径,如:E:\a.dbf
            FileInfo fi = new FileInfo(filePath);
            string mulu = fi.DirectoryName;
            string filename = fi.Name;

            OleDbConnection conn = new OleDbConnection();
            string table = filePath;

            string connStr = @"Provider=VFPOLEDB.1;Data Source=" + mulu + ";Collating Sequence=MACHINE";
            connStr = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source= "+mulu+"; Extended Properties='dBASE 5.0'";
            conn.ConnectionString = connStr;
            conn.Open();

            string sql = @"select * from " + filename;
            OleDbDataAdapter da = new OleDbDataAdapter(sql, conn);
            DataTable dt = new DataTable();
            da.Fill(dt);