C# 中的 DBF 文件读取器出错
本文关键字:出错 读取 文件 中的 DBF | 更新日期: 2023-09-27 18:36:38
错误:查询中的语法错误。 不完整的查询子句。请帮助我。
string db_file = null;
OpenFileDialog op = new OpenFileDialog();
op.InitialDirectory = Application.StartupPath + "''out";
op.Filter = "DBF file|*.dbf";
if (op.ShowDialog() == DialogResult.OK)
{
db_file = op.FileName;
FileInfo fi = new FileInfo(op.FileName);
String ConnectionString;
ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + fi.DirectoryName + ";Extended Properties=dBase 5.0;Mode=Read|Write|Share Deny None;Persist Security Info=True";
System.Data.OleDb.OleDbConnection dBaseConnection;
dBaseConnection = new System.Data.OleDb.OleDbConnection(ConnectionString);
dBaseConnection.Open();
System.Data.OleDb.OleDbCommand dBaseCommand;
dBaseCommand = new System.Data.OleDb.OleDbCommand("Select * From '" + Path.GetFileNameWithoutExtension(fi.Name) + "'", dBaseConnection);
System.Data.OleDb.OleDbDataReader dBaseDataReader;
dBaseDataReader = dBaseCommand.ExecuteReader();
while (dBaseDataReader.Read())
{
MessageBox.Show("x");
}
dBaseDataReader.Close();
错误:查询中的语法错误。 不完整的查询子句。
我建议使用VfpOleDb提供程序。 下面是使用该提供程序的连接字符串:
ConnectionString = "Provider=VfpOleDb;Data Source=" + fi.DirectoryName;
试试这个:
("Select * From " + Path.GetFileNameWithoutExtension(fi.Name) , dBaseConnection)
没有引号"路径.."。
希望对您有所帮助。