使用过程插入后更新DataGrid

本文关键字:更新 DataGrid 插入 过程 | 更新日期: 2023-09-27 18:30:00

我知道有人问我这个问题,但我不明白为什么这个动作如此复杂。所以我有一个Produs

SELECT TOP 1000 [IDProdus]
    ,[Denumire]
    ,[UM]
    ,[Pret]
    ,[IDFurnizor]
    ,[IDCategorie]
    ,[IDTipProdus]
    ,[OperatorAdaugare]
    ,[DataAdaugare]
    ,[OperatorModificare]
    ,[DataModificare]
FROM [Proiect].[dbo].[Produse]

这是我表的列。我通过Visual Studio的数据源GUI添加了一个DataSet,其中包含该表的内容(我没有编写实际的代码)。

现在我有一个过程,将在该表中插入新行。

这是代码:

private void dToolStripMenuItem_Click(object sender, EventArgs e)
{
    SqlConnection conn = new SqlConnection("connection-string-here");
    string Query = "spGE_getProduse_Edit"; // Stored procedure name.
    int Integer; 
    conn.Open();
    // Creating SqlCommand object
    SqlCommand com = new SqlCommand(Query, conn );
    // Here we declaring command type as stored procedure:
    com.CommandType = CommandType.StoredProcedure;
    com.Parameters.AddWithValue("@IDProdus", 0);       
    com.Parameters.AddWithValue("@Denumire ",
        denumireTextBox.Text.ToString());     
    com.Parameters.AddWithValue("@UM ",
        uMTextBox.Text.ToString());
    com.Parameters.AddWithValue("@Pret ",
        Double.Parse(pretTextBox.Text));
    com.Parameters.AddWithValue("@IDFurnizor ",
        Int16.Parse(iDFurnizorTextBox.Text));
    com.Parameters.AddWithValue("@IDCategorie ",
        Int16.Parse(iDCategorieCombobox.SelectedValue.ToString()));
    com.Parameters.AddWithValue("@IDTipProdus ",
        Int16.Parse(iDTipProdusCombobox.SelectedValue.ToString()));
    com.Parameters.Add("@IDProdusScris", SqlDbType.BigInt);
    com.Parameters["@IDProdusScris"].Direction =
        ParameterDirection.Output;
    com.ExecuteNonQuery();
    conn.Close();   
    Integer =
        Int32.Parse(com.Parameters["@IDProdusScris"].Value.ToString());
}

现在插入后,我想用新记录更新myGrid。我试过了CCD_ 4和CCD_。

有没有办法更新网格?对于VS来说,这看起来是一项简单的任务,但我找不到一个简单的解决方案。

我在MSDN上看到和阅读的内容看起来像是一些非常复杂的操作,只是为了简单的刷新。(这是关于获取行的状态,并在状态为Add的情况下插入行)。

那么,有没有简单的方法可以做到这一点,或者我必须写一个方法,每次我想刷新我的dataGridView(我的意思是重新查询我的表并重建dataSource

使用过程插入后更新DataGrid

这样尝试:

CCD_ 8和CCD_。

您可以使用预编译的存储过程

Create Procedure Sp_getProducts
as
BEGIN
SELECT TOP 1000 [IDProdus]
      ,[Denumire]
      ,[UM]
      ,[Pret]
      ,[IDFurnizor]
      ,[IDCategorie]
      ,[IDTipProdus]
      ,[OperatorAdaugare]
      ,[DataAdaugare]
      ,[OperatorModificare]
      ,[DataModificare]
  FROM [Proiect].[dbo].[Produse]
END

使用使用语句的代码

using (SqlConnection conn = new SqlConnection("connection-string-here"))
{
conn.Open();
using(SqlCommand cmd=new SqlCommand("Sp_getProducts",conn))
{
cmd.CommandType = CommandType.StoredProcedure; 
SqlDataAdapter da = new SqlDataAdapter(cmd);
DataTable ds = new DataTable();
da.Fill(ds);
gridView.DataSource = ds;
gridView.DataBind();
conn.Close(); 
}
}

尝试重置数据源:

dataGridView1.DataSourcce = null;
dataGridView1.DataSource = [YOUR DATASET];
dataGridView1.Refresh();
dataGridView1.Update();