使用 sqlite、wpf 和 C# 在链接的数据库表中插入和更新数据网格行

本文关键字:更新 插入 数据 网格 数据网 wpf sqlite 使用 链接 数据库 | 更新日期: 2023-09-27 18:35:14

我的 sqlite 代码用于将数据库表链接到数据网格是:

 sqlitecon.Open();
 string Query2 = "Select * from Security_details "; 
 SQLiteCommand createCommand2 = new SQLiteCommand(Query2, sqlitecon);  createCommand2.ExecuteNonQuery();
 SQLiteDataAdapter dataAdp2 = new SQLiteDataAdapter(createCommand2);
 DataTable dt2 = new DataTable("Security_details");
 dataAdp.Fill(dt2);
 datagrid_security.ItemsSource = dt2.DefaultView;
 dataAdp2.Update(dt2); 
 sqlitecon.Close();

此代码在窗体加载事件期间将数据库表链接到数据网格。

我希望用户能够:

  • 在数据网格上添加新行 插入数据库
  • 编辑数据网格上的现有行 更新到数据库中。

以下查询是我的数据库字段

SQLiteCommand comm = new SQLiteCommand("update Security_details  " + 
      "set id=@id,Code=@Code,Description=@Description,Rate=@Rate," + 
      "Qty=@Qty,Amount=@Amount,Remarks=@Remarks where id=@id", sqlitecon);

请告诉我通过数据网格插入和编辑数据库表的命令集?谢谢

使用 sqlite、wpf 和 C# 在链接的数据库表中插入和更新数据网格行

SQLiteDataAdapter的声明移动到全局类级别,并在那里声明一个SQLiteCommandBuilder。然后,在将数据绑定到网格之前,初始化 SQLiteCommandBuilder,该生成器将自动创建适用于表的 UPDATE/INSERT/DELETE 命令(前提是 SELECT 返回表的主键)

此时,当您准备好将数据提交到数据库时,请调用全局 SQLiteDataAdapter 实例的 Update 方法

public class YourClass
{
     SQLiteDataAdapter dataAdp2;
     SQLiteCommandBuilder cmdBuilder;
     .....

     public void BindMyGrid()
     {
          sqlitecon.Open();
          string Query2 = "Select * from Security_details "; 
          SQLiteCommand createCommand2 = new SQLiteCommand(Query2, sqlitecon);                
          dataAdp2 = new SQLiteDataAdapter(createCommand2);
          cmdBuilder = new SQLiteCommandBuilder(dataAdp2);
          DataTable dt2 = new DataTable("Security_details");
          dataAdp2.Fill(dt2);
          datagrid_security.ItemsSource = dt2.DefaultView;
          sqlitecon.Close();
     }
     ....
     public void SubmitData()
     {
          dataAdp2.Update((datagrid_security.ItemsSource As DataView).Table);
     }
     ......
}

如果您需要对此过程进行更深入的讨论,可以阅读这篇MSDN文章,它相当古老,涉及SQL Server,并且 VB.NET,但基本概念是相同的。