繁体   English   中英

使用具有ms-access的C#的INSERT INTO语句中的语法错误

[英]Syntax error in INSERT INTO statement using C# with ms-access

我在弄清楚我的代码出什么问题时遇到了麻烦。 我试图通过C#在Access Db中添加一条记录,但是遇到一个异常,该异常表明我的SQL语句语法错误。

 private void buttonSUB_Click(object sender, EventArgs e)
    {
        string Adrs = textADRS.Text;
        string Fname = textFN.Text;
        string Mname = textMN.Text;
        string Lname = textLN.Text;
        string Pos = textPOS.Text;

        try
        {

            OleDbConnection con = new OleDbConnection();
            con.ConnectionString = @"Provider = Microsoft.ACE.OLEDB.12.0; Data Source = C:\\Users\\genesis\\Documents\\Database1.accdb";
            OleDbCommand cmd = new OleDbCommand("Insert into Employees (FN,MN,LN,Address,Position) Values (@FirstName,@MidName,@LastName,@Address,@Position)",con);
            cmd.Parameters.Add(new OleDbParameter("@FirstName", Fname));
            cmd.Parameters.Add(new OleDbParameter("@MidName", Mname));
            cmd.Parameters.Add(new OleDbParameter("@LastName", Lname));
            cmd.Parameters.Add(new OleDbParameter("@Address", Adrs));
            cmd.Parameters.Add(new OleDbParameter("@Position", Pos));
            con.Open();
            cmd.ExecuteNonQuery();
            MessageBox.Show("Record Submitted", "Nice!");
            con.Close();
        }

        catch (Exception ex) {
            MessageBox.Show(ex.Message);
        }



    }

Access SQL保留字列表中POSITION已定义为保留关键字。

如果使用保留字或符号来命名表中的字段,Access会警告您该字已保留,并且在引用该字段时可能会遇到错误。 如果使用保留字来命名控件,对象或变量,也可能会遇到错误。

如果已经使用了保留字,则可以在每次出现该字时都使用方括号([])来避免出现错误消息。

因此,您需要添加方括号以将其用作表名:

OleDbCommand cmd = new OleDbCommand(
                 @"INSERT INTO Employees (FN, MN, LN, Address, [Position]) 
                   VALUES (@FirstName, @MidName, @LastName, @Address, @Position)", con);

注意:保留字在Access用法中不区分大小写,因此,每次使用保留字的情况都必须放在方括号内。

试试这样的:

cmd.Parameters.Add(new OleDbParameter("@FirstName","'" + Fname "'"));

带字符串参数的单棚。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM