首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用带有ms-access的C#的INSERT INTO语句语法错误

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

Stack Overflow用户
提问于 2017-06-21 18:31:41
回答 2查看 3K关注 0票数 1

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

代码语言:javascript
复制
 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);
        }



    }
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-06-22 03:11:26

访问SQL保留字列表中,POSITION已经定义为保留关键字。

如果使用保留字或符号来命名表中的字段,Access将警告您该单词是保留的,并且在引用该字段时可能会遇到错误。如果使用保留字命名控件、对象或变量,也可能会遇到错误。 如果保留词已经在使用中,则可以避免错误消息,方法是用方括号( )将每个单词的出现括起来。

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

代码语言:javascript
复制
OleDbCommand cmd = new OleDbCommand(
                 @"INSERT INTO Employees (FN, MN, LN, Address, [Position]) 
                   VALUES (@FirstName, @MidName, @LastName, @Address, @Position)", con);

注:保留字在存取使用上是不区分大小写的,因此每次使用保留字时都必须放在方括号内。

票数 2
EN

Stack Overflow用户

发布于 2017-06-21 18:45:30

试试这样的方法:

代码语言:javascript
复制
cmd.Parameters.Add(new OleDbParameter("@FirstName","'" + Fname "'"));

带有字符串参数的单子叶树。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44683696

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档