前些天就遇到一个将dbf数据文件读取到datagridview里,然后再导入到
SQLServer数据库里,难点就是如何将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);
本文介绍了一种使用C#读取FoxPro数据库(dbf文件)的方法,并提供了具体实现代码。通过安装VFPOLEDB组件并利用OleDb类,可以将dbf数据读取到DataTable中。
1690

被折叠的 条评论
为什么被折叠?



