C# BindingNavigator кнопка Сохранить

Пожалуйста, помогите мне в этом, так как я почти целый день борюсь за то, как правильно определить кнопку сохранения в навигаторе привязки. Я новичок в C#, поэтому, пожалуйста, потерпите меня.

Итак, у меня есть эта простая форма, в которой я показываю по очереди строки из таблицы. Я добавил навигатор привязки и создал новую кнопку с именем SaveItem, чтобы я мог сохранить любые изменения, внесенные в отображаемую строку:

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.Configuration;
using System.Data.SqlClient;

namespace MyApp
{
   public partial class DefineBusinessGroups : Form
   {
      BindingSource BGbindSource = new BindingSource();
      public string UserId { get; set; }
      public string UserName { get; set; }
      public string UserType { get; set; }
      public string BssGr { get; set; }

      public void Fill_DataSource()
      {

          SqlConnection conn = 
          new SqlConnection(
          ConfigurationManager.ConnectionStrings["SRDBConnection"].ConnectionString);
          try
          {
              conn.Open();
              SqlDataAdapter da1 = 
                  new SqlDataAdapter(
                      new SqlCommand("select * from BusinessGroups", conn));
              DataSet ds = new DataSet();
              da1.Fill(ds);
              BGbindSource.DataSource = ds.Tables[0];
              bindingNavigator1.BindingSource = BGbindSource;

              //BusinessGroupCode
              textBox1.DataBindings.Add(
                  new Binding("Text", 
                              this.BGbindSource, 
                              "BusinessGroupCode", 
                              true, 
                              DataSourceUpdateMode.OnPropertyChanged));

              //BusinessGroupName
              textBox2.DataBindings.Add(
                  new Binding("Text", 
                              this.BGbindSource, 
                              "BusinessGroupName", 
                              true, 
                              DataSourceUpdateMode.OnPropertyChanged));

              //BusinessGroupDesc
              textBox3.DataBindings.Add(
                  new Binding("Text", 
                              this.BGbindSource, 
                              "BusinessGroupDescription", 
                              true, 
                              DataSourceUpdateMode.OnPropertyChanged));

              //BusinessGroupId
              textBox4.DataBindings.Add(
                  new Binding("Text", 
                              this.BGbindSource, 
                              "BGId", 
                              true, 
                              DataSourceUpdateMode.OnPropertyChanged));

          }
          catch (Exception)
          {
              toolStripStatusLabel3.Text = "Database Is Offline or" + 
                                           "the Connection is not set correctly!";
          }
          finally
          {
              conn.Close();
          }
      }

      public DefineBusinessGroups()
      {
         InitializeComponent();
      }

      private void DefineBusinessGroups_Load(object sender, EventArgs e)
      {
         Fill_DataSource();
         toolStripStatusLabel3.Text = "UserName: " + this.UserName;
         toolStripStatusLabel4.Text = "UserType: " + this.UserType;
         toolStripStatusLabel5.Text = "Business Group: " + this.BssGr;
         this.Text = this.Text + " as " + this.UserType;

         if (UserType == "ADM")
         {
             textBox1.ReadOnly = false;
             textBox2.ReadOnly = false;
             textBox3.ReadOnly = false;

         }
         else
         {
             textBox1.ReadOnly = true;
             textBox2.ReadOnly = true;
             textBox3.ReadOnly = true;
             bindingNavigatorAddNewItem.Visible = false;
             bindingNavigatorDeleteItem.Visible = false;
             bindingNavigatorSaveItem.Visible = false;
         }

      }

      private void bindingNavigatorSaveItem_Click(object sender, EventArgs e)
      {
          if (BGbindSource.Current == null) return;

          SqlConnection conn = 
          new SqlConnection(
          ConfigurationManager.ConnectionStrings["SRDBConnection"].ConnectionString);
          try
          {
              conn.Open();
              SqlCommand sqlcmd = new SqlCommand("update BusinessGroups"
                  + "set BusinessGroupCode=@BGCode,"
                  + "BusinessGroupName=@BGName,"
                  + "BusinessGroupDescription=@BGDesc"
                  + "where BGId=@BGId", conn);
              //BGCode
              SqlParameter param1 = new SqlParameter();
              param1.ParameterName = "@BGCode";
              param1.Value = textBox1;
              sqlcmd.Parameters.Add(param1);

              //BGName
              SqlParameter param2 = new SqlParameter();
              param2.ParameterName = "@BGName";
              param2.Value = textBox2;
              sqlcmd.Parameters.Add(param2);

              //BGDesc
              SqlParameter param3 = new SqlParameter();
              param3.ParameterName = "@BGDesc";
              param3.Value = textBox3;
              sqlcmd.Parameters.Add(param3);

              //BGId
              SqlParameter param4 = new SqlParameter();
              param4.ParameterName = "@BGId";
              param4.Value = textBox4;
              sqlcmd.Parameters.Add(param4);

              //Execute the update
              sqlcmd.ExecuteNonQuery();
              MessageBox.Show("Update done!");

          }
          catch (Exception)
          {
              MessageBox.Show("Something went wrong!");
          }
          finally
          {
              conn.Close();
          }
      }
   }
}

Когда я нажимаю кнопку сохранения, я получаю текст сообщения из ветви catch. Фактически, я хотел бы сохранить только информацию из текущей выбранной строки (BGId).

Спасибо!

Отредактировано позже: код для кнопки сохранения был неправильным. Вот правильный код:

private void bindingNavigatorSaveItem_Click(object sender, EventArgs e)
      {
          //if (BGbindSource.Current == null) return;

          SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["SRDBConnection"].ConnectionString);
          try
          {
              conn.Open();
              SqlCommand sqlcmd = new SqlCommand("if exists (select 1 from BusinessGroups where BGId=@BGId) "
                  + " update BusinessGroups "
                  + " set BusinessGroupCode=@BGCode, "
                  + " BusinessGroupName=@BGName, "
                  + " BusinessGroupDescription=@BGDesc "
                  + " where BGId=@BGId "
                  + " else "
                  + " insert into BusinessGroups (BusinessGroupCode,BusinessGroupName,BusinessGroupDescription) "
                  + " select @BGCode,@BGName,@BGDesc " 
                  , conn);
              //BGCode
              SqlParameter param1 = new SqlParameter("@BGCode", SqlDbType.NVarChar, 30 );
              param1.Value = textBox1.Text;
              sqlcmd.Parameters.Add(param1);

              //BGName
              SqlParameter param2 = new SqlParameter("@BGName", SqlDbType.NVarChar, 150);
              param2.Value = textBox2.Text;
              sqlcmd.Parameters.Add(param2);

              //BGDesc
              SqlParameter param3 = new SqlParameter("@BGDesc", SqlDbType.NVarChar, 1000);
              param3.Value = textBox3.Text;
              sqlcmd.Parameters.Add(param3);

              //BGId
              SqlParameter param4 = new SqlParameter("@BGId", SqlDbType.Int);
              if (textBox4.Text.Trim() == "")
              {
                  param4.Value = -999;
              }
              else 
              {
                  param4.Value = textBox4.Text;
              }
              sqlcmd.Parameters.Add(param4);

              sqlcmd.ExecuteNonQuery();
              BGbindSource.ResetBindings(false);
              MessageBox.Show("Successfully saved!");

          }
          catch (Exception)
          {
              MessageBox.Show("Something went wrong!");
              throw;
          }
          finally
          {
              if (conn != null)  conn.Close();
          }
      }

0 ответов

Другие вопросы по тегам