DataGrid取索引问题 参考CurrencyManager类,有一Position属性 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 转帖:这个问题在CSDN上以及被提及多次了。该问题产生的原因在于当DataGrid重新排序后,相应的DataTable是保持不变的,重新进行排序的其实是相应的DataView(您可以通过DataView.Sort得到当前的排序)。因此,要取得重新排序后的DataGrid的某一行的数据不能简单的取DataTable中该行的值(实际上这两行并不对应),而应该和DataView关联或者是通过其他的途径。DataView dv=new DataView(dataset.table1); datagrid.DataSource=dv; ...DataRow currentRow = dataView[dataGrid1.CurrentRowIndex].Row;可以取到DataGrid的当前行。另一种方法是通过CurrencyManager来取得当前行:CurrencyManager cm = (CurrencyManager)BindingContext[dataGrid.DataSource, dataGrid.DataMember];DataRow dr = ((DataRowView)cm.Current).Row;DataView dv=new DataView(dataset.table1); datagrid.DataSource=dv; 以上代码不能在datagrid.MouseDown事件中。只有在之前就将datagrid绑定到dataview才行。否则,每次得到的DataGrid1.CurrentRowIndex都是0 这种情况下,建议还是读取数据库里的索引主键比较好,你就直接确定他是那条记录得了,不要用datagrid的索引 我就是用主键,可用DataSet.Find方法虽然可以找到记录,可返回的是DataRow,我还是不能用Position定位到这条记录,因为还是不知道它的索引,我是希望在选定DataGrid中的一条记录后打开一个新窗口用来显示和修改这条记录的详细内容,因为这个窗口的控件绑定到DataSet,所以我要用Position定位到这条记录。谢谢各位帮忙,请再给点提示,一定给分,多谢。 得到主键后,使用另一个DATASET直接SELECT你需要的数据,将新窗口的数据连接这个新的DATASET上。 由于系统缓冲区空间不足或队列已满,不能执行套接字上的操作 怎么用C#开发这样的接口啊? 谢谢~ 将用户表里的数据全部加载到内存中,怎么样? C#游戏架构问题 重开一贴再问 怎样配置Visual Studio 2005 的默认语言? 一个小程序,求助 分不多了,就给100吧,Redmine,哪位大牛再用,我今天试着按照网上的教程安装,出了点错误~ 谢谢 我在项目添加一个新窗体,编译后怎么提示项目未加载 嫁接PB与C#! 如何在c#程序中新建一个数据库并把程序结果填入数据库?
这个问题在CSDN上以及被提及多次了。该问题产生的原因在于当DataGrid重新排序后,相应的DataTable是保持不变的,重新进行排序的其实是相应的DataView(您可以通过DataView.Sort得到当前的排序)。因此,要取得
重新排序后的DataGrid的某一行的数据不能简单的取DataTable中该行的值(实际上这两行并不对应),而应该和DataView关联或者是通过其他的途径。DataView dv=new DataView(dataset.table1);
datagrid.DataSource=dv;
...DataRow currentRow = dataView[dataGrid1.CurrentRowIndex].Row;
可以取到DataGrid的当前行。另一种方法是通过CurrencyManager来取得当前行:
CurrencyManager cm = (CurrencyManager)
BindingContext[dataGrid.DataSource, dataGrid.DataMember];
DataRow dr = ((DataRowView)cm.Current).Row;DataView dv=new DataView(dataset.table1);
datagrid.DataSource=dv;
以上代码不能在datagrid.MouseDown事件中。只有在之前就将datagrid绑定到dataview才行。否则,每次得到的DataGrid1.CurrentRowIndex都是0