Winform DataGrideView怎么修改默认排序

shsyzl007 2019-11-04 02:08:09
有一列里面的数据有些是空的,当首次点击表头时默认把空数据显示在前面了,好像是顺序排序;

怎么改变DataGrideView列的默认排序,当第一次点击列表头时把有数据的行排在前面?
...全文
194 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
引用 3 楼 shsyzl007 的回复:
数据表好几个字段都是这样的,比如其中两列数据

A D
- -
C -
- -
- X
D -
按照数据源排序只能显示一种情况,而且默认得按时间排序

我要查看第一列数据要点两次表头,第二列数据也是如此。第一次点击空数据都排在前面。。

那么你就不用直接绑定,通过sql获取到表格内容填充至dataset后自己写代码将dataset里面的内容填充至datagridview里,这样就能够变换datagridview的显示。
比如说,从数据库获得的dataset是你这样的
A D
- -
C -
- -
- X
D -
而你要让datagridview第一次显示成这样
C -
D -
- -
- -
- X
思路就是遍历dataset的datatable的第一列,当不为空时直接复制在datagridview里,为空放在另外一个datatable里,遍历完后就把另外的datatable追加在datagridview,这样datagridview显示出来的就是
C -
D -
- -
- -
- X

如果你点击第二列表头时要显示出第二列数据的第一行不为空,道理也是如此,就遍历dataset的datatable的第二列,当不为空时直接复制在datagridview里,为空放在另外一个datatable里,遍历完后就把另外的datatable追加在datagridview,这样datagridview显示出来的就是
- X
- -
C -
- -
D -。
于是你就可以把填充datagridview的代码写成一个通用的方法,假如是paixu(列参数),传入参数则为第几列,load里默认第一列排序,在表头点击事件里就对应传参数就行了。这样你程序运行后默认是第一列为空的在后面,当你点击不同列的表头时,就会更新datagridview,将对应列的不为空的行按照顺序显示出来。

shsyzl007 2019-11-04
  • 打赏
  • 举报
回复
数据表好几个字段都是这样的,比如其中两列数据

A D
- -
C -
- -
- X
D -
按照数据源排序只能显示一种情况,而且默认得按时间排序

我要查看第一列数据要点两次表头,第二列数据也是如此。第一次点击空数据都排在前面。。
qq_34057056 2019-11-04
  • 打赏
  • 举报
回复
对数据源进行排序
  • 打赏
  • 举报
回复
你在写sql语句时把顺序改变下就行了啊,这样填充的dataset就不是默认的,绑定到DataGrideView时就不用改了

111,093

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧