1.三个属性让DBGridEH可以点击表头自动排序

只要设置下面三个属性:

ColumDefValues->Title->TitleButton设为TRUE  
sortlocal   设为TRUE
OptionsEH->dghautosortmarking设为TRUE

最后,一定要记得在pas文件的uses里引用上ehlib***,我这里的是ehlibCDS,网上也有的是ehlibBDE。我这里的情况是如果没有引用这个ehlibCDS,在点击dbgrideh表头时出现了小三角号,但就是不排序。

2.ehlib 自动过滤和排序

--------------------------------------------------------------------------------

delphi版本

   6

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!

 
 
3.DBGridEH点击标题自动排序的设定及排序标志相反BUG的修正
 
 

一、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控件】的更多相关文章

  1. Atitit. BigConfirmTips 控件 大数据量提示确认控件的原理and总结O9

    Atitit. BigConfirmTips 控件 大数据量提示确认控件的原理and总结O9 1. 主要的涉及的技术 1 2. 主要的流程 1 3. 调用法new confirmO9t(); 1 4. ...

  2. c# 将页面导出到word(含图片及控件)

    /// <summary> /// 创建word /// <param name="filePath">文件路径 </param> /// &l ...

  3. Jquery显示和隐藏元素或设为只读(含Ligerui的控件禁用,实例说明)

    一.隐藏和显示元素 $('#button_save_12').css('display', 'none'); // 隐藏按钮 $('#button_save_12').css('display', ' ...

  4. Web大文件上传(断点续传)控件-Xproer.HttpUploader6-安装教程

      安装教程: IE8控件安装教程 IE9控件安装教程 Firefox控件安装教程 Chrome控件安装教程 Chrome 45+控件安装教程 相关问题: 提示Runtime Error错误 360拦 ...

  5. QRowTable表格控件-支持hover整行、checked整行、指定列排序等

    目录 一.开心一刻 二.嘴一嘴 三.效果展示 四.浅谈实现 五.自定义数据源 1.data函数 2.flags函数 六.自定义视图 1.目的 2.问题分析 七.测试 八.相关文章 原文链接:QRowT ...

  6. QRowTable表格控件(五)-重写表头排序、支持第三次单击恢复默认排序

    目录 一.原生表格 二.效果展示 三.实现方式 1.排序列定制 2.排序交互修改 四.相关文章 原文链接:QRowTable表格控件(五)-重写表头排序.支持第三次单击恢复默认排序 一.原生表格 开发 ...

  7. 扩展GridView实现的一个自定义无刷新分页,排序,支持多种数据源的控件TwfGridView

    最近项目View层越来越趋向于无刷新化,特别是数据展示方面,还要对Linq有很好的支持.在WebFrom模式的开发中,GridView是一个功能很强大,很常用的控件,但是他也不是完美的,没有自带的无刷 ...

  8. [WP8.1UI控件编程]Windows Phone大数据量网络图片列表的异步加载和内存优化

    11.2.4 大数据量网络图片列表的异步加载和内存优化 虚拟化技术可以让Windows Phone上的大数据量列表不必担心会一次性加载所有的数据,保证了UI的流程性.对于虚拟化的技术,我们不仅仅只是依 ...

  9. Atitit.hybrid混合型应用 浏览器插件,控件的实现方式 浏览器运行本地程序的解决方案大的总结---提升用户体验and开发效率..

    Atitit.hybrid混合型应用 浏览器插件,控件的实现方式 浏览器运行本地程序的解决方案大的总结---提升用户体验and开发效率.. 1. hybrid App 1 1.1. Hybrid Ap ...

  10. 因用了NeatUpload大文件上传控件而导致Nonfile portion > 4194304 bytes错误的解决方法

    今天遇到一个问题,就是“NeatUpload大文件上传控件而导致Nonfile portion > 4194304 bytes错误”,百度后发现了一个解决方法,跟大家分享下: NeatUploa ...

随机推荐

  1. util工具函数

    1 /** 2 * @param {Function} fn 防抖函数 3 * @param {Number} delay 延迟时间 4 */ 5 export function debounce(f ...

  2. 引入阿里在线图标(微信小程序)

    https://www.bilibili.com/video/BV1WJ41197sD?p=49

  3. vue动态组件使用

  4. feign接口自动生成工具

    最近发现开发spring cloud时,编写feign接口是一件痛苦的事,不仅要编写feign接口,还有fallback.请求参数和返回值等,大量重复工作,很浪费时间. 于是便想到可以编写工具自动生成 ...

  5. MPC 是下一代私钥安全的7大原因

    PrimiHub一款由密码学专家团队打造的开源隐私计算平台,专注于分享数据安全.密码学.联邦学习.同态加密等隐私计算领域的技术和内容. 多重签名钱包与单一密钥钱包相比,因其提升了资产安全性,如今已成为 ...

  6. [转帖]Nginx 保留 Client 真实 IP

    https://lqingcloud.cn/post/nginx-01/#:~:text=%E5%9C%A8%20Nginx%20%E4%B8%AD%E5%8F%AF%E4%BB%A5%E9%80%9 ...

  7. TiDB的搭建与维护过程

    TiDB的搭建与维护过程 背景 总结一下TiDB的搭建以及简单维护过程. 目标: 简单快速的创建TiDB数据库,以及进行备份恢复等工作. TiDB 简介 TiDB(全称:Ti Distributed ...

  8. [转帖]Oracle数据库下PreparedStatementCache内存问题解决方案

    https://github.com/alibaba/druid/wiki/Oracle%E6%95%B0%E6%8D%AE%E5%BA%93%E4%B8%8BPreparedStatementCac ...

  9. [转帖]高性能 -Nginx 多进程高并发、低时延、高可靠机制在百万级缓存 (redis、memcache) 代理中间件中的应用

    https://xie.infoq.cn/article/2ee961483c66a146709e7e861 关于作者 前滴滴出行技术专家,现任 OPPO 文档数据库 mongodb 负责人,负责 o ...

  10. buildkit 官网 service 资料

    [Unit]   Description=BuildKit   Requires=buildkit.socket   After=buildkit.socket   Documentation=htt ...