欢迎光临
我们一直在努力

当单击dbgrid中的标题栏时,进行排序_delphi教程

建站超值云服务器,限时71元/月

 

方法:


关键是用DBGrid的事件 OnTitleClick


首先判断单击是哪一列,


     i:=Column.Index;


然后要确定是哪个字段


    Field:=DBGrid1.Columns[i].FieldName+ ASC;


最后进行排序:


    qryWork.Sort:=Field;


 


上面仅仅是进行升序排列,若要添加降序排列,则要用 DESC


若要单击后,升序,再单击,降序…..


则要用到一个奇偶判断


我的一个例子


(其中的bSort:Boolean,在FormShow的时候初始化)


procedure TfmPlayVideo.DBGrid1TitleClick(Column: TColumn);
var
    i:integer;
    fieldname:string;
begin//排序
    i:=Column.Index;
    if bSort then
    begin
        fieldname:=DBGrid1.Columns[i].FieldName+ ASC;
        bSort:=False;
    end
    else
    begin
        fieldname:=DBGrid1.Columns[i].FieldName+ DESC;
        bSort:=True;
    end;
    qryShow.Sort:=fieldname;
end;

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 当单击dbgrid中的标题栏时,进行排序_delphi教程
分享到: 更多 (0)