Delphi ClientDataSet 排序[1]

Delphi ClientDataSet 排序[1] 

1、单个字段排序 (索引名称自定义,例如:sSort)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
//升序
with ClientDataSet1  do
begin
  IndexDefs.Update;   //更新
  if IndexDefs.IndexOf( 'sSort' )>=0 then DeleteIndex('sSort');   //删除索引
  AddIndex('sSort',Column.FieldName, [ixPrimary], Column.FieldName );   //添加索引  升序
  IndexName:= 'sSort'//索引
  First;   //回到第一行
end;
 
//降序  ixDescending
with ClientDataSet1  do
begin
  IndexDefs.Update;
  if  IndexDefs.IndexOf( 'sSort' )>=0 then DeleteIndex('sSort');
  AddIndex('sSort',Column.FieldName,[ixDescending],Column.FieldName);  
  IndexName:='sSort';
  First;
end;

2、多个排序字段 (例如:Field1,Field2)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
with ClientDataSet1  do
begin
  IndexDefs.Update;
   if  IndexDefs.IndexOf( 'sSort' )>=0 then DeleteIndex( 'sSort' );
  AddIndex('sSort','Field1, Field2',[],'');
  IndexName:='sSort';
  First;
end;
 
with ClientDataSet1  do
begin
  IndexDefs.Update;
  if IndexDefs.IndexOf( 'sSort' )>=0 then DeleteIndex( 'sSort' );
  AddIndex('sSort','Field1,Field2',[],'Field1, Field2');
  IndexName:='sSort' ;
  First;
end;

 

TIndexOption参数取值:

1
2
3
4
5
6
7
8
9
TIndexOption = (
        ixPrimary,      //初级  升序
         ixUnique,      //唯一值
        ixDescending,   //降序
        ixCaseInsensitive,  //不区分大小写
        ixExpression,    //表达式
        ixNonMaintained  //不保持
);
  TIndexOptions = set of TIndexOption;   

  

  

  

 

 

创建时间:2021.01.25  更新时间:

 

posted on   滔Roy  阅读(1043)  评论(0编辑  收藏  举报

编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报

导航

点击右上角即可分享
微信分享提示