DBGRIDEH 排序 我自己大总结【含DBX,Dac控件】
1.三个属性让DBGridEH可以点击表头自动排序
只要设置下面三个属性:
ColumDefValues->Title->TitleButton设为TRUE
sortlocal 设为TRUE
OptionsEH->dghautosortmarking设为TRUE
最后,一定要记得在pas文件的uses里引用上ehlib***,我这里的是ehlibCDS,网上也有的是ehlibBDE。我这里的情况是如果没有引用这个ehlibCDS,在点击dbgrideh表头时出现了小三角号,但就是不排序。
2.ehlib 自动过滤和排序
--------------------------------------------------------------------------------
delphi版本
ehlib版本
5.2.84
方式
TADOQuery + TDataSetDriverEh + TMemTableEh + TDataSource +
DBGridEh
--------------------------------------------------------------------------------------
过滤:
1. DBGridEh.STFilter.Local := True
DBGridEh.STFilter.Visible :=
True
2. uses EhLibMTE;
DONE!
排序
1. DBGridEh.SortLocal := True
DBGridEh.OptionsEh.dghAutoSortMarking := True
DBGridEh.OptionsEh.dghMultiSortMarking := True
DONE!
一、DBGridEH点击标题自动排序的设定
①按DataSet源类型的不同,在工程中引用EhLib相应排
序单元文件,如uses EhLibAdo,uses EhLibCDS,uses EhLibBDE、uses
EhLibDBX等,我一般都会在一个公共文件中进行引用,这样就无须在所有用到DBGridEH的单元中都城加入引用语句了,如在DataModule
之类的公共窗体中uses EhLibXXX;一次就行了。
②设置DBGridEH的OptionsEH.dghAutoSortMarking := True;如果希望多列排序还可设置OptionsEH.dghMultiSortMarking := True;
③如果你的DataSet源是TClientDataSet,且只想对已下载到本地的数据进行排序的话,则请设置DBGridEH的SortLocal := True;
④
设置DBGridEH中所有希望进行排序的列标题的按钮属性为True,即Columns[i].Title.TitleButton :=
True;字段类型为LookUp类型或计算字段不能排序,故这类字段
列的TitleButton应设置为False,否则点击标题进行排序时会发生异常。
至此,点击DBGridEH标题就可以自动排序了,多列排序需按下Ctrl键。
但是有一个小 BUG(我使用的是EhLibCDS),那就是标题列上的排序图标和排序结果不相符,当升序排列时出现的不是向上的箭头,而是向下的箭头,降序则相反。这应该是EhLib中的设置标题重画方法时赋反了一个逻辑标志值。如何修正它呢?
二、排序标志相反BUG的修正
方法一、最佳方法,找到问题源,修正它!可惜,我没找到。
方法二、修改DBGridEH.res,把两个bmp图标文件对换一下,有点麻烦。
方法三、大致翻阅一下DBGridEH源码,发现排序图标文件标志是由两个常量定义的,
const
...
bmSmDown = 'DBSMDOWNEH';
bmSmUp = 'DBSMUPEH';
...
这就好办了,在此对换一下,又安全又快捷
//bmSmDown = 'DBSMDOWNEH'; //这是原始内容
//bmSmUp = 'DBSMUPEH'; //这是原始内容
bmSmDown = 'DBSMUPEH'; // Modified by 小宇飞刀 2009-10-24 10:31:26
bmSmUp = 'DBSMDOWNEH'; // Modified by 小宇飞刀 2009-10-24 10:31:26
至此,一切OK!
=======================================2014.03.14======================================
我自己的总结,我以后开发不在用ado了,以后就用TSqlConnection + TSqlQuery + TDataSetPrevider + TClientDataSet + TDataSource 这种模式了
所以DbGrideh 要想自动排序,只需要排序 本地的内存数据库就可以了,不用写代码 ,dbgrideh的设置如下:
1.ColumDefValues->Title->TitleButton设为TRUE
2.sortlocal 设为TRUE
3.OptionsEH->dghautosortmarking设为TRUE
就可以了!...
=============================2014.03.19世界变化的真快,我现在用上FireDac了,巨爽无比,DBX控件Bug太多,最终放弃了==============
通过这次转变,学习了太多的东西,知道原来链接驱动还有UniDac,FireDac且更加强大方便,还跨平台,网店管家用的就是UniDac...;delphi 收购了AnyDac改名成FireDac
这个以后才是delphi的方向,FireDac + FireMonkey 跨平台的开发语言,原生程序 跨平台的框架 跨平台的数据库链接驱动,方向巨对,Delphi又要腾飞了,传奇又要开始了
用上了FireDac后感觉就是 下一代 跨平台的 BDE 我靠,巨强...;
针对FireDac 下 dbgrideh 排序的问题,是这样的;
1.ColumDefValues->Title->TitleButton设为TRUE
2.sortlocal 设为TRUE
3.OptionsEH->dghautosortmarking设为TRUE
4.把EhLibFireDAC添加到项目中就可, 其他需要排序的窗体,不需要引用,只需要 把这个添加到项目中就可.草草草.....

DBGRIDEH 排序 我自己大总结【含DBX,Dac控件】的更多相关文章
- Atitit. BigConfirmTips 控件 大数据量提示确认控件的原理and总结O9
Atitit. BigConfirmTips 控件 大数据量提示确认控件的原理and总结O9 1. 主要的涉及的技术 1 2. 主要的流程 1 3. 调用法new confirmO9t(); 1 4. ...
- c# 将页面导出到word(含图片及控件)
/// <summary> /// 创建word /// <param name="filePath">文件路径 </param> /// &l ...
- Jquery显示和隐藏元素或设为只读(含Ligerui的控件禁用,实例说明)
一.隐藏和显示元素 $('#button_save_12').css('display', 'none'); // 隐藏按钮 $('#button_save_12').css('display', ' ...
- Web大文件上传(断点续传)控件-Xproer.HttpUploader6-安装教程
安装教程: IE8控件安装教程 IE9控件安装教程 Firefox控件安装教程 Chrome控件安装教程 Chrome 45+控件安装教程 相关问题: 提示Runtime Error错误 360拦 ...
- QRowTable表格控件-支持hover整行、checked整行、指定列排序等
目录 一.开心一刻 二.嘴一嘴 三.效果展示 四.浅谈实现 五.自定义数据源 1.data函数 2.flags函数 六.自定义视图 1.目的 2.问题分析 七.测试 八.相关文章 原文链接:QRowT ...
- QRowTable表格控件(五)-重写表头排序、支持第三次单击恢复默认排序
目录 一.原生表格 二.效果展示 三.实现方式 1.排序列定制 2.排序交互修改 四.相关文章 原文链接:QRowTable表格控件(五)-重写表头排序.支持第三次单击恢复默认排序 一.原生表格 开发 ...
- 扩展GridView实现的一个自定义无刷新分页,排序,支持多种数据源的控件TwfGridView
最近项目View层越来越趋向于无刷新化,特别是数据展示方面,还要对Linq有很好的支持.在WebFrom模式的开发中,GridView是一个功能很强大,很常用的控件,但是他也不是完美的,没有自带的无刷 ...
- [WP8.1UI控件编程]Windows Phone大数据量网络图片列表的异步加载和内存优化
11.2.4 大数据量网络图片列表的异步加载和内存优化 虚拟化技术可以让Windows Phone上的大数据量列表不必担心会一次性加载所有的数据,保证了UI的流程性.对于虚拟化的技术,我们不仅仅只是依 ...
- Atitit.hybrid混合型应用 浏览器插件,控件的实现方式 浏览器运行本地程序的解决方案大的总结---提升用户体验and开发效率..
Atitit.hybrid混合型应用 浏览器插件,控件的实现方式 浏览器运行本地程序的解决方案大的总结---提升用户体验and开发效率.. 1. hybrid App 1 1.1. Hybrid Ap ...
- 因用了NeatUpload大文件上传控件而导致Nonfile portion > 4194304 bytes错误的解决方法
今天遇到一个问题,就是“NeatUpload大文件上传控件而导致Nonfile portion > 4194304 bytes错误”,百度后发现了一个解决方法,跟大家分享下: NeatUploa ...
随机推荐
- P5704 【深基2.例6】字母转换
1.题目介绍 2.题解 2.1 ASCII码表 在ASCII码表中,小写字母=大写字母+32,则大写字母=小写字母-32 #include<iostream> using namespac ...
- c#下使用WM_COPYDATA
[DllImport("User32.dll")] public static extern int SendMessage(IntPtr hwnd, int msg, int w ...
- Linux-关机重启和注销
- [转帖]JVM随笔 --- 安全点(safe point)与 安全区域( safe region)
https://zhuanlan.zhihu.com/p/461298916 11 人赞同了该文章 最近回顾 JVM safe point 与 safe region 又有一些新的感悟与收获,特别写篇 ...
- [转帖]JVM性能提升50%,聊一聊背后的秘密武器Alibaba Dragonwell
https://zhuanlan.zhihu.com/p/453437019 今年四月五日,阿里云开放了新一代ECS实例的邀测[1],Alibaba Dragonwell也在新ECS上进行了极致的优化 ...
- [转帖]python字符串如何删除后几位
https://www.python51.com/jc/15070.html 1.首先在jupyter notebook中新建一个空白的python文件: 2.然后定义一个字符串,用字符串截取的方式打 ...
- Springboot 使用nacos鉴权的简单步骤
Springboot 使用nacos鉴权的简单步骤 背景 前端时间nacos爆出了漏洞. 因为他的默认token固定,容易被利用. 具体的问题为: QVD-2023-6271 漏洞描述:开源服务管理平 ...
- [百度贴吧]部分CPU的SPEC2006int 结果
这些测试成绩基本上是本人自己测试的结果.下表中有来自spec官网的两个成绩,因为测试年份较早,系统环境和编译器都较老,测试成绩本人实测的还差,所以仅作为参考.部分测试启用了自动并行和附加的优化库,是为 ...
- Rendezvous hashing算法介绍
Rendezvous hashing Rendezvous hashing用于解决分布式系统中的分布式哈希问题,该问题包括三部分: Keys:数据或负载的唯一标识 Values:消耗资源的数据或负载 ...
- Concat、Push、Spread syntax性能差异对比
今天在力扣上做了一道数组扁平化的题,按理来说,应该熟能生巧了,但是在使用concat时候超出了时间限制,使用push可以通过,代码如下: /** * @describe 使用concat,超出时间限制 ...