C#DataGridView与DataTable绑定的问题
有两个DataGridView控件,点击DataGridView1中的数据查出的明细在DataGridView2中显示,针对DataGridView2有两个DataTab...
有两个DataGridView控件,点击DataGridView1中的数据查出的明细在DataGridView2中显示,
针对DataGridView2有两个DataTable类的对象DataA和DataB,DataA用来绑定DataGridView2,DataB是汇总DataGridView1中的所有查出的数据的明细,只是要点中才在DataGridView2显示的数据。
DataGridView2中有一列数据是要更改的,改了之后是不会写到汇总的那个DataTable中去的,这样我改了之后点另一条数据,这改的数据就丢失了,我希望我点DataGridView1然后就在DataGridView2中显示,点中的记录,改了之后这些数据写到DataTable等DataGridView1中的所有记录改完再一次提交。
希望哪位高手能帮忙指点一下
更新DataGridView中的数据同步到汇总表DataTable
感激不尽 展开
针对DataGridView2有两个DataTable类的对象DataA和DataB,DataA用来绑定DataGridView2,DataB是汇总DataGridView1中的所有查出的数据的明细,只是要点中才在DataGridView2显示的数据。
DataGridView2中有一列数据是要更改的,改了之后是不会写到汇总的那个DataTable中去的,这样我改了之后点另一条数据,这改的数据就丢失了,我希望我点DataGridView1然后就在DataGridView2中显示,点中的记录,改了之后这些数据写到DataTable等DataGridView1中的所有记录改完再一次提交。
希望哪位高手能帮忙指点一下
更新DataGridView中的数据同步到汇总表DataTable
感激不尽 展开
1个回答
展开全部
先看看我理解了你的意思没有,我复述一遍:表格1是汇总表,表格2是明细表,表格2一次性只能显示表格1的一条记录的明细,表格2还支持编辑数据,以便最终更新到数据库。问题是表格1切换记录时没有把表格2的更新保存。
解决办法:
先确定明细表的主键是什么,先假定你能得到表格2的每条记录的唯一键,如果没有,那么请在数据库加此键。
用字典Dictionary<string, string>来记录你的更改,两个string分别是键值和改动后的值。
在切换表格1的记录的时候,如果表格2已经有数据,且有更改,则先把当前表格2的改动记录到字典里面。
最后字典里就包含了所有需要提交的值,用大概的语句就可以更新数据库了
foreach(var v in dic)
sql: update table set (colname = v.Value) where key = v.Key
更多追问追答
追问
很感谢你的回答,但是我这里主键是由三个字段组成,这些数据由于是多表查询出来的,要确定他们的唯一性得用多个字段,而且由于我这边有些特殊,处理数据并不是前台直接完成的,是需要将数据传到后台进行处理的,所以我需要的只是将数据写到这个DataTable的汇总表下
追答
其实我还有另一个办法,初始化界面的时候就把表格2的所有数据加载进来,根据表格1的选择隐藏不需要的行,这样最终表格2的绑定数据也是全部修改过的数据。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询