麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

一個很實用的Ehlib排序函數,適合ADO

2019-11-18 18:03:23
字體:
來源:轉載
供稿:網友
 

Ehlib3.0版本以上雖然支持排序功能,但不支持帶有Order By的SQL語句,而且排序很慢;我寫的這個排序函數,利用ADO的sort方法,排序很快,幾萬條數據也是很快。該函數支持Lookup字段排序,不支持計算字段排序,因為計算字段值在內存里高速運算。排序分為:升序、降序和默認三種,支持排序圖標。

PRocedure  SortDBGridEh(Sender: TObject; ACol: Integer;
  Column: TColumnEh);
var
  FieldName, SortStr: string;
begin
  Screen.Cursor := crSQLWait;
  try
    if (Sender is TDBGridEh) and
      ((Sender as TDBGridEh).DataSource.DataSet <> nil) then
    begin
      if not ((Sender as TDBGridEh).DataSource.DataSet is TCustomADODataSet) then
        Exit;

      if not (Sender as TDBGridEh).DataSource.DataSet.Active then
        Exit;

      FieldName := Column.FieldName;
      if (Sender as TDBGridEh).DataSource.DataSet.FindField(FieldName).IsBlob then
        Exit;

      if (Sender as TDBGridEh).DataSource.DataSet.FieldByName(FieldName).FieldKind =
        fkData then
        SortStr := FieldName
      else if (Sender as TDBGridEh).DataSource.DataSet.FieldByName(FieldName).FieldKind =
        fkLookup then
        FieldName := (Sender as TDBGridEh).DataSource.DataSet.FieldByName(FieldName).KeyFields
      else
        FieldName := '';

      if (FieldName = '') or (Pos(';', FieldName) > 0) then
        Exit;
      case Column.Title.SortMarker of
        smNoneEh:
          begin
            Column.Title.SortMarker := smUpEh;
            TCustomADODataSet((Sender as TDBGridEh).DataSource.DataSet).Sort :=
              FieldName;

          end;
        smUpEh:
          begin
            Column.Title.SortMarker := smDownEh;
            TCustomADODataSet((Sender as TDBGridEh).DataSource.DataSet).Sort :=
              FieldName + ' DESC';
          end;
        smDownEh:
          begin
            Column.Title.SortMarker := smNoneEh;
            TCustomADODataSet((Sender as TDBGridEh).DataSource.DataSet).Sort := '';
          end;
      end;
    end;
  finally
    Screen.Cursor := crDefault;
  end;
end;

--程序實現如下:
--在DBGridEh的事件OnTitleBtnClick引用該函數即可:
procedure TFrmU_BasicSetup.dbgAddrCodeTitleBtnClick(Sender: TObject;
  ACol: Integer; Column: TColumnEh);
begin
   SortDBGridEh(Sender, ACol, Column);
end;
--為了保證表格的每一列都能點擊觸發排序,你需要將你需要排序的列屬性
--  Title->TitleButton設置為True。


上一篇:DBGrid中用光標鍵控制Cell

下一篇:關于開發系統后門軟件的幾點思路

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

主站蜘蛛池模板: 国产精品资源手机在线播放 | 国产91亚洲精品一区二区三区 | 久色乳综合思思在线视频 | 姑娘第5集高清在线观看 | 一级毛片在线免费观看视频 | 国产精品视频一区二区三区四区国 | 国产成人综合在线观看 | 男男啪羞羞视频网站 | 1314av| 日本成人午夜视频 | 欧美一区高清 | 欧美一级片网站 | 成人免费网视频 | 黄色av网站在线观看 | 91精品国产91 | 特级毛片a级毛片100免费 | 欧美一级毛片特黄黄 | 99日韩精品视频 | 吾色视频 | 91在线视频观看 | 成人国产综合 | 国产自在线 | 亚洲网站在线观看 | 色蜜桃av | 日本不卡一区二区三区在线 | 在线观看中文字幕av | 亚洲欧洲日产v特级毛片 | 国产妞干网 | 中文字幕 亚洲一区 | a级黄色片视频 | 成人国产精品色哟哟 | 亚洲成人免费网站 | 欧美自拍三区 | 国产精品美女久久久久久网站 | 操碰视频在线观看 | 久综合 | 国产91一区 | 九九热精品在线 | 综合国产一区 | 亚洲综合一区二区三区 | 91 在线|