首页 > 编程语言 > 详细

DataGridView和DataTable同步排序

时间:2016-01-15 12:37:14      阅读:179      评论:0      收藏:0      [点我收藏+]

当对绑定DataTable的DataGridView排序时,DataTable是用其维护的DataView或者DataViewManager实现排序逻辑的,并没有改变DataSource对应的DataTable,所以当我们要获取DataGridView中的排序时,比如用排序后的DataTable打印、导出,就必须常用附加逻辑。

代码如下

 1         /// <summary>
 2         /// 获取DataGridView绑定的包含排序状态的DataTable
 3         /// </summary>
 4         /// <param name="dgv">绑定DataTable的DataGridView</param>
 5         /// <returns>包含排序状态的DataTable</returns>
 6         public DataTable GetSortDataTable(DataGridView dgv)
 7         {
 8             DataView dv = (dgv.DataSource as DataTable).DefaultView;//得到DataView
 9             if (dgv.SortedColumn != null)//判断是否有排序
10             {
11                 dv.Sort = dgv.SortedColumn.DataPropertyName + (dgv.SortOrder == SortOrder.Ascending ? " asc" : " desc");//排序
12             }
13             return dv.ToTable();//返回DataTable
14         }

 

DataGridView和DataTable同步排序

原文:http://www.cnblogs.com/YangDengmeng/p/5132637.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!