0

我用于将 db 表链接到数据网格的 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();

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

我希望用户能够:

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

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

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);

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

4

1 回答 1

3

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

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

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 中,但基本概念是相同的。

于 2013-10-13T16:37:12.220 回答