使用 OleDbCommandBuilder 时出现访问 SQL 语法错误

本文关键字:SQL 语法 错误 访问 OleDbCommandBuilder 使用 | 更新日期: 2023-09-27 18:36:35

我将在 C# 中使用 OleDbDataAdapter 在 Access 数据库中插入数据,但我收到消息错误 插入命令中的语法错误

BackgroundWorker worker = new BackgroundWorker();
OleDbDataAdapter dbAdapter new OleDbDataAdapter();
OleDbConnection dbConnection = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=E:''PMS.mdb");
worker = new BackgroundWorker();
worker.WorkerReportsProgress = true;
worker.DoWork += InsertJob;
worker.ProgressChanged += InsertJobCompleted;
worker.RunWorkerAsync(args);

插入工作功能是:

private void InsertJob(object sender, DoWorkEventArgs e)
{
     var args = (InsertJobArgs)e.Argument;
     try
        {
            dbAdapter.SelectCommand = new OleDbCommand("SELECT * FROM Sheet", dbConnection);                
            dbAdapter.Fill(args.DataTable);
            var builder = new OleDbCommandBuilder(dbAdapter);
            var row = args.DataTable.NewRow();
            row["UserName"] = args.Entry.UserName;
            row["Password"] = args.Entry.Password;
            args.DataTable.Rows.Add(row);
            dbAdapter.InsertCommand = builder.GetInsertCommand();               
            dbAdapter.Update(args.DataTable);
            builder.Dispose();
        }
        catch (Exception ex)
        {
            args.Exception = ex;
            worker.ReportProgress(0, args);
            return;
        }
        worker.ReportProgress(100, args);
}

我收到在线错误:dbAdapter.Update(args.DataTable);

我尝试使用Visual Studio调试它,发现所有InsertCommand参数值都null

我尝试在调用dbAdapter.Update(args.DataTable);之前通过此代码手动插入它

dbAdapter.InsertCommand.Parameters[0].Value = args.Entry.UserName;
dbAdapter.InsertCommand.Parameters[1].Value = args.Entry.Password;

使用 OleDbCommandBuilder 时出现访问 SQL 语法错误

试试这个:

紧跟在行之后

var builder = new OleDbCommandBuilder(dbAdapter);

添加两行

builder.QuotePrefix = "[";
builder.QuoteSuffix = "]";

这将告诉OleDbCommandBuilder将表和列名称括在方括号中,生成一个 INSERT 命令,如下所示

INSERT INTO [TableName] ...

而不是默认表单

INSERT INTO TableName ...
如果

任何表或列名称包含空格或"有趣"字符,或者如果它们恰好是 Access SQL 中的保留字,则需要方括号。(在您的情况下,我怀疑您的表有一个名为 [Password] 的列,PASSWORD是 Access SQL 中的保留字。