Ehlib3.0以后的版本虽然支持排序功能,但不支持带有Order By的SQL语句,而且排序很慢;我写的这个排序函数,利用ADO的sort方法,排序很快,几万条数据也是很快。该函数支持Lookup字段排序,不支持计算字段排序,因为计算字段值在内存里高速运算。排序分为:升序、降序和默认三种,支持排序图标。
--程序实现如下:
--在DBGridEh的事件OnTitleBtnClick引用该函数即可:
--为了保证表格的每一列都能点击触发排序,你需要将你需要排序的列属性
-- Title->TitleButton设置为True。
注意:只需选中DBGridEH的列--->Title->TitleButton设置为True即可,其他不用设置。无需设置DBGridEH--->OptionsEh--->ghAutoSortMarking为True,否则在遇到带有Order by语句时会报错。
原帖转自:http://blog.youkuaiyun.com/xieyunc/archive/2009/05/02/4142891.aspx
本文介绍了一种针对DBGridEh组件的快速排序方法,通过使用ADO的sort方法实现了高效的数据排序功能,支持升序、降序及默认排序,并且支持排序图标显示。此方法不适用于带有OrderBy的SQL语句或计算字段。
126

被折叠的 条评论
为什么被折叠?



