-1

我正在尝试创建更新 WINFORM,背景故事是当用户双击特定 GUID 时表单将从 dataGridView 获取信息。

我的问题是,当用户输入信息并单击提交按钮时,我收到错误消息:

解析查询时出错。[令牌行号 = 1,令牌行偏移量 = 66,错误令牌 = Desc]。

这可能是一个简单的错误,我只是在看,但感谢任何帮助。按钮单击的代码是:

private void sbmtChng_Click(object sender, EventArgs e)
{
        string conString = Properties.Settings.Default.CurricularChangeTrackerConnectionString;

        using (SqlCeConnection conn = new SqlCeConnection(conString))
        {
            try
            {
                conn.Open();

                string cmdString = "UPDATE Changes SET "
                     + "ProgramCode=@ProgramCode,CourseNum=@CourseNum,Desc=@Desc,ScreenCom=@ScreenCom,PECAprv=@PECAprv,SenAprv=@SenAprv,EffDte=@EffDte,APG=@APG,Analysis=@Analysis,Matrix=@Matrix,DESE=@DESE"
                     + " WHERE Code_ID=@Code_ID";

                using (SqlCeCommand cmd = new SqlCeCommand(cmdString, conn))
                {
                    cmd.Parameters.AddWithValue("@Code_ID", SqlDbType.UniqueIdentifier).Value = Code_ID;
                    cmd.Parameters.AddWithValue("@ProgramCode", SqlDbType.NVarChar).Value = PrgmCode;
                    cmd.Parameters.AddWithValue("@CourseNum", SqlDbType.NVarChar).Value = CrseLbl.Text;
                    cmd.Parameters.AddWithValue("@Desc", SqlDbType.NVarChar).Value = ChngDes.Text;
                    cmd.Parameters.AddWithValue("@ScreenCom", SqlDbType.NVarChar).Value = scrnCmtDte.Text;
                    cmd.Parameters.AddWithValue("@PECAprv", SqlDbType.NVarChar).Value = pecAprDte.Text;
                    cmd.Parameters.AddWithValue("@SenAprv", SqlDbType.NVarChar).Value = senAprvDateTimePicker.Text;
                    cmd.Parameters.AddWithValue("@EffDte", SqlDbType.NVarChar).Value = effDte.Text;
                    cmd.Parameters.AddWithValue("@APG", SqlDbType.NChar).Value = checkBox5.Text;
                    cmd.Parameters.AddWithValue("@Analysis", SqlDbType.NChar).Value = checkBox6.Text;
                    cmd.Parameters.AddWithValue("@Matrix", SqlDbType.NChar).Value = checkBox7.Text;
                    cmd.Parameters.AddWithValue("@DESE", SqlDbType.NChar).Value = checkBox8.Text;
                    cmd.ExecuteNonQuery();
                    conn.Close();

                    /*this.Controls.Clear();
                    this.InitializeComponent();
                    this.Close();
                    */
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
    }
4

1 回答 1

4

DESC是保留关键字。重命名列(首选)或更改代码以将列名括在方括号中:

+ "ProgramCode=@ProgramCode,CourseNum=@CourseNum,[Desc]=@Desc,..."
// ----------------------------------------------^----^                     
于 2012-05-30T15:14:32.057 回答