使用 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);
请告诉我通过数据网格插入和编辑数据库表的命令集?谢谢
将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,但基本概念是相同的。