使用 OleDb 插入访问时出现语法错误

Posted

技术标签:

【中文标题】使用 OleDb 插入访问时出现语法错误【英文标题】:Syntax error when Insert to Access using OleDb 【发布时间】:2011-10-02 10:24:59 【问题描述】:

我在 vb.net 方面没有很多经验,但我正在尝试使用 OleDB 插入一条带有 String,string,Yes/no(studentname, number,gender) 的记录。但是,当我插入它时,会引发一个异常,指出我对“插入”查询的语法无效。我无法发现错误。

测试用例:

txtName.Text = "asdasdasd"
txtPhone.Text = "123456789"
rGender.Checked = True

代码如下:

    cmd = New OleDbCommand()
    With cmd
        .Connection = cn
        .CommandText = "INSERT INTO [Student] (StudentName, Number, Gender) VALUES(@Name,@Number,@Gender)"
        .CommandType = CommandType.Text
        .Parameters.AddWithValue("@Name", txtName.Text)
        .Parameters.AddWithValue("@Number", txtPhone.Text)
        .Parameters.AddWithValue("@Gender", rGender.Checked)
    End With

【问题讨论】:

【参考方案1】:

似乎是字段名称“数字”的问题,它是 MSAccess 中的一个关键字 - http://support.microsoft.com/kb/286335。

【讨论】:

我不记得有保留关键字列表。我之前只使用了 2 到 3 次访问权限,非常感谢 Anuraj【参考方案2】:

号码是reserved字,

INSERT INTO [Student] ([StudentName], [Number], [Gender]) VALUES(@Name,@Number,@Gender)

【讨论】:

以上是关于使用 OleDb 插入访问时出现语法错误的主要内容,如果未能解决你的问题,请参考以下文章

在 INSERT INTO 语句中插入值时出现语法错误。 -VB 和 ACCESS 2013

插入 JSON 对象时出现 Python pymysql 语法错误

尝试使用多个值插入 SQL Server 时出现不正确的语法错误

在 PHP 中插入 MySQL 表时出现语法错误 [重复]

尝试使用触发器以将行插入另一个表时出现语法错误

使用 C# windows 窗体向 Ms Access 数据库插入新记录时出现语法错误