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 ...
随机推荐
- 问题--之前必须结合fn+f1,f2等才能调节音量,亮度,现在只按f1,f2就调节,导致快捷键冲突
1.问题 问题如上 2.解决方式 问题原因: 热键默认打开,用fn加上esc开启了热键的默认设置 解决: 再按一次fn加上esc关闭热键的默认设置
- 【TouchGFX】visua studio 自定义路径宏
很好奇 touchgfx 的 visual studio 工程文件中路径符号 $(TouchGFXReleasePath)是哪里定义的,经查这就是一个宏替换 自定义宏方式
- java - 递归排序 - 求数组最小值
// 递归求数组最小值 public class Bubble { // 定义存储最小值的变量 static int min; public static void main(String[] arg ...
- MyBatis02:CRUD操作
CRUD操作 namespace 这个是命名空间,不可缺少,更不能写错 配置文件中namespace中的名称为对应Mapper接口或者Dao接口的全限定类名,完整包名,必须一致! Select(用于查 ...
- [转帖]Navicat连接openGauss数据库报错
news/2023/10/19 21:23:19 错误信息:fe_sendauth:invalid authentication request from server:AUTH_REQ_SASL_C ...
- [转帖]Jmeter学习笔记(十七)——jmeter目录结构
原文链接:http://www.cnblogs.com/zichuan/p/6938772.html 一.bin目录examples: 目录中有CSV样例 jmeter.bat windows ...
- [转帖]linux 部署jmeter&报错处理
一.linux 安装jdk Java Downloads | Oracle 二. linux上传jmeter 2.1 上传jmeter jmeter 下载地址: Apache JMeter - Dow ...
- ebpf 单行程序学习
ebpf 单行程序学习 背景 公司方神借给我一本: <BPF之巅:洞悉linux系统和应用性能>纸质书 拿回家晚上在沙发上看了几天. 感觉书很厚看的不是很系统. 仅能凭自己的感觉总结一下这 ...
- [转帖]Linux系统下cpio命令详解
简介 cpio主要是解压或者将文件压缩到指定文件中即copy-in和copy-out模式. 参数说明 参数 参数说明 -i copy-in模式,解压文件 -o copy-out模式,即压缩文件 -d ...
- [转帖]关于F5负载均衡你认识多少?
https://www.cnblogs.com/xiexun/p/10718348.html 网络负载均衡(load balance),就是将负载(工作任务)进行平衡.分摊到多个操作单元上进行执行,例 ...