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();   
错误

:查询中的语法错误。 不完整的查询子句。

C# 中的 DBF 文件读取器出错

我建议使用VfpOleDb提供程序。 下面是使用该提供程序的连接字符串:

ConnectionString = "Provider=VfpOleDb;Data Source=" + fi.DirectoryName;

试试这个:

("Select * From " + Path.GetFileNameWithoutExtension(fi.Name) , dBaseConnection)

没有引号"路径.."。

希望对您有所帮助。