[英]Update Command Executenonquery - Syntax Error
我試圖在C#中更新一些數據
“')'附近的語法不正確。” 在“ da.UpdateCommand.ExecuteNonQuery();”行中。
我瀏覽了很多時間的代碼,現在再也看不到錯誤。 所以我認為應該沒問題,但不是。 您能看一下下面的代碼嗎?
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;
namespace klinika
{
public partial class frModWla : Form
{
DataSet ds = new DataSet();
SqlConnection cs = new SqlConnection("Data Source=.\\SQLEXPRESS; Initial Catalog=Klinika; Integrated security=TRUE");
SqlDataAdapter da = new SqlDataAdapter();
BindingSource bs = new BindingSource();
public frModWla()
{
InitializeComponent();
}
private void btnWyswietl_Click(object sender, EventArgs e)
{
bindingClear();
da.SelectCommand = new SqlCommand("SELECT * FROM tbWlasciciel", cs);
ds.Clear();
da.Fill(ds);
dg.DataSource = ds.Tables[0];
bs.DataSource = ds.Tables[0];
tbxImie.DataBindings.Add(new Binding("Text", bs, "Imie"));
tbxNazwisko.DataBindings.Add(new Binding("Text", bs, "Nazwisko"));
tbxMiejscowosc.DataBindings.Add(new Binding("Text", bs, "Miejscowosc"));
tbxKodPocztowy.DataBindings.Add(new Binding("Text", bs, "Kod_pocztowy"));
tbxAdres.DataBindings.Add(new Binding("Text", bs, "Adres"));
tbxTelefon.DataBindings.Add(new Binding("Text", bs, "Telefon"));
tbxEmail.DataBindings.Add(new Binding("Text", bs, "Email"));
rekord();
}
private void bindingClear()
{
tbxImie.DataBindings.Clear();
tbxNazwisko.DataBindings.Clear();
tbxMiejscowosc.DataBindings.Clear();
tbxKodPocztowy.DataBindings.Clear();
tbxAdres.DataBindings.Clear();
tbxTelefon.DataBindings.Clear();
tbxEmail.DataBindings.Clear();
}
private void btnPoprzedni_Click(object sender, EventArgs e)
{
bs.MovePrevious();
dgUpdate();
rekord();
}
private void btnNastepny_Click(object sender, EventArgs e)
{
bs.MoveNext();
dgUpdate();
rekord();
}
private void btnPierwszy_Click(object sender, EventArgs e)
{
bs.MoveFirst();
dgUpdate();
rekord();
}
private void btnOstatni_Click(object sender, EventArgs e)
{
bs.MoveLast();
dgUpdate();
rekord();
}
private void dgUpdate()
{
dg.ClearSelection();
dg.Rows[bs.Position].Selected = true;
rekord();
}
private void rekord()
{
lblRecords.Text = "Rekord " + bs.Position + " z " + (bs.Count - 1);
}
private void btnUaktualnij_Click(object sender, EventArgs e)
{
da.UpdateCommand = new SqlCommand("UPDATE tbWlasciciel SET NAZWISKO = @NAZWISKO, IMIE = @IMIE, MIEJSCOWOSC = @MIEJSCOWOSC, KOD_POCZTOWY = @KOD_POCZTOWY, ADRES = @ADRES, TELEFON = @TELEFON, EMAIL = @EMAIL WHERE ID_WLASCICIELA = @ID_WLASCICIELA)", cs);
da.UpdateCommand.Parameters.Add("@IMIE", SqlDbType.VarChar).Value = tbxImie.Text;
da.UpdateCommand.Parameters.Add("@NAZWISKO", SqlDbType.VarChar).Value = tbxNazwisko.Text;
da.UpdateCommand.Parameters.Add("@MIEJSCOWOSC", SqlDbType.VarChar).Value = tbxMiejscowosc.Text;
da.UpdateCommand.Parameters.Add("@KOD_POCZTOWY", SqlDbType.VarChar).Value = tbxKodPocztowy.Text;
da.UpdateCommand.Parameters.Add("@ADRES", SqlDbType.VarChar).Value = tbxAdres.Text;
da.UpdateCommand.Parameters.Add("@TELEFON", SqlDbType.VarChar).Value = tbxTelefon.Text;
da.UpdateCommand.Parameters.Add("@EMAIL", SqlDbType.VarChar).Value = tbxEmail.Text;
da.UpdateCommand.Parameters.Add("@ID_WLASCICIELA", SqlDbType.Int).Value = ds.Tables[0].Rows[bs.Position][0];
cs.Open();
da.UpdateCommand.ExecuteNonQuery();
MessageBox.Show("Dane w bazie danych zostały zaktualizowane!", "Aktualizacja danych");
cs.Close();
}
}
}
您需要在SqlCommand的末尾刪除“)”。 您沒有開頭(
因此告訴您)
結尾是無效的語法。
只需在您的SqlCommand
刪除)
。 它位於@ID_WLASCICIELA
參數的右側。 您一次打開了括號,但兩次關閉了括號。
用這個:
da.UpdateCommand = new SqlCommand("UPDATE tbWlasciciel SET NAZWISKO = @NAZWISKO, IMIE = @IMIE, MIEJSCOWOSC = @MIEJSCOWOSC, KOD_POCZTOWY = @KOD_POCZTOWY, ADRES = @ADRES, TELEFON = @TELEFON, EMAIL = @EMAIL WHERE ID_WLASCICIELA = @ID_WLASCICIELA", cs);
在您的WHERE子句中,它看起來像一個額外的“)”:
...@EMAIL WHERE ID_WLASCICIELA = @ID_WLASCICIELA)", cs)
應該在哪里:
...@EMAIL WHERE ID_WLASCICIELA = @ID_WLASCICIELA", cs)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.