0
private void btnSubmit_Click(object sender, EventArgs e)
        {
            OleDbCommand cmd;

            string cmdstring = "INSERT INTO Names (Surname,FName) VALUES('" + txtSurname.Text + "','" + txtFName.Text + "')";

            OleDbConnection myConnection = new OleDbConnection(ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString);

            cmd = new OleDbCommand(cmdstring, myConnection);
            myConnection.Open();
            cmd.ExecuteNonQuery();
            myConnection.Close();
}

我想添加SurnameFName访问数据库,但是出现了这样的错误"syntax error"。我不知道为什么。

4

1 回答 1

3

以下是您的查询失败的两个可能原因。

  1. Names是一个保留字
  2. SurnameFName包含撇号的值。

您可以通过将表名括在方括号中来避免第一个问题 ... [Names]。但如果可能的话,最好选择一个不同的名称。

如果按照其他人的建议切换到参数查询,则可以避免第二个问题。但在这种情况下,仍将表名括起来。

于 2013-04-21T17:53:30.350 回答