度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 9127|回复: 18
打印 上一主题 下一主题

[分享] 利用DataView的RowFilter实现网格数据动态过滤。

  [复制链接]

78

主题

634

帖子

1598

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1598
跳转到指定楼层
楼主
发表于 2020-3-13 23:37:26 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
首先请大家点开下图,看大图。


图中可以看出,我们实现了SQL方式去过滤网格部件的数据,为什么可以采用这种sql的方式来过滤数据呢?网格部件过滤功能不是不支持这种写法吗?
如果你有上面的疑问,那么表示你对网格部件还比较熟悉。接下来,我来讲讲这是为什么:
实际上,我们在窗体中,构建了一个文本输入框,一个搜索按钮和一个清空按钮,来模拟了网格部件的查找面板。结合DataView的RowFilter方法,可以实现SQL查询式的过滤数据(但仅限于本地DataTable中的数据)。
实际上,DataView的RowFilter具有很强的过滤功能,我们在平台网格部件中,只需要对其设置值即可,设置方法为:

  1. 网格部件1.DataTable.DefaultView.RowFilter="SQL条件"
复制代码

即可实现DataView的数据过滤。
我在上面窗体中,过滤按钮单击事件中写了以下代码:
  1. 通讯录网格.DataTable.DefaultView.RowFilter=过滤文本.Value
复制代码
即模拟出了网格部件的过滤效果,并且比网格部件的过滤功能更加强大,可以支持任意sql过滤条件,如 or 等。
DataView过滤还可以支持null等查询,如
  1. dataView1.RowFilter = " sex is null ";
复制代码

或者将null字段转换为值再对比:
  1. dataView1.RowFilter = " Isnull( sex, '空') = '空' ";
复制代码
      值得注意的是:DataView是DateTable相关联 的一个视图而已,无论你如何使用RowFilter,DataView虽然被改变,但 DateTable数据不会减少,所以你不要幻想连续使用多个RowFilter 来得到叠加过滤的效果,一个DataView只支持一个RowFilter,你只能使用 not ,and 来连接多个过滤条件。




分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

78

主题

634

帖子

1598

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1598
沙发
 楼主| 发表于 2020-3-13 23:38:54 | 只看该作者
国际惯例沙发自己坐。
回复 支持 反对

使用道具 举报

78

主题

634

帖子

1598

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1598
板凳
 楼主| 发表于 2020-3-13 23:42:35 | 只看该作者
如果要放弃过滤,显示所有行,则可使用:
dataView1.RowFilter = null;
或者
dataView1.RowFilter = "";
回复 支持 反对

使用道具 举报

67

主题

685

帖子

1815

积分

作者

Rank: 7Rank: 7Rank: 7

积分
1815
地板
发表于 2020-3-14 09:37:06 | 只看该作者
这个对操作上有很大左右,或者二次开发的时候设置筛选条件也比较方便。
回复 支持 反对

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
5#
发表于 2020-3-14 14:33:37 | 只看该作者
这个功能真心很实用
回复 支持 反对

使用道具 举报

348

主题

3572

帖子

9376

积分

论坛元老

Rank: 8Rank: 8

积分
9376
6#
发表于 2020-3-14 15:27:32 | 只看该作者
请问网格部件自带的属性:查找面板支持这个功能吗?
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复 支持 反对

使用道具 举报

198

主题

1313

帖子

3784

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
3784
7#
发表于 2020-3-14 18:23:39 | 只看该作者
这个使用以前还没用过呢。
回复 支持 反对

使用道具 举报

328

主题

3738

帖子

8566

积分

作者

Rank: 7Rank: 7Rank: 7

积分
8566
QQ
8#
发表于 2020-3-14 21:58:28 | 只看该作者
有图有真相
回复 支持 反对

使用道具 举报

78

主题

634

帖子

1598

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1598
9#
 楼主| 发表于 2020-3-14 22:37:56 | 只看该作者
偶尔能解决很实际的问题。
回复 支持 反对

使用道具 举报

348

主题

3572

帖子

9376

积分

论坛元老

Rank: 8Rank: 8

积分
9376
10#
发表于 2020-4-2 15:06:23 | 只看该作者
掌握好了再灵活运用,确实强大
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2024-12-22 20:30 , Processed in 0.227098 second(s), 31 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表