国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

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

一個很實用的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

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

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

新聞熱點

疑難解答

圖片精選

網友關注

主站蜘蛛池模板: 疏勒县| 泸水县| 崇明县| 博湖县| 太原市| 南投县| 金昌市| 海伦市| 温宿县| 安图县| 当雄县| 漾濞| 乳山市| 克拉玛依市| 介休市| 华容县| 罗甸县| 玉田县| 镶黄旗| 沁源县| 策勒县| 三门县| 济阳县| 承德县| 东源县| 射阳县| 禄丰县| 砀山县| 滨州市| 漯河市| 曲麻莱县| 肥城市| 桐梓县| 河西区| 临汾市| 万盛区| 朝阳区| 通山县| 土默特右旗| 当雄县| 洱源县|