亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? othersort.pas

?? 中國移動大客戶管理系統
?? PAS
字號:
//------------------------------------------------------------
//      作者:曾慶順
//      模塊:通用排序窗口
//      時間:2001.07.08
//      功能介紹:P_OtherSort( Query:TQuery;DbGRid:TwwDBGrid);
//                Query 為對應的數據集,DbGRid對應的數據控件---TwwDBGrid控件infopower控件組
//-----------------------------------------------------------
unit OtherSort;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  Grids, ExtCtrls, Buttons, StdCtrls,dbtables,dbgrids,db, Wwdbigrd, Wwdbgrid;

type
  TOtherSortFrm = class(TForm)
    Panel1: TPanel;
    StringGrid1: TStringGrid;
    Panel2: TPanel;
    StringGrid2: TStringGrid;
    Panel3: TPanel;
    Panel4: TPanel;
    SpeedButton1: TSpeedButton;
    SpeedButton2: TSpeedButton;
    procedure FormCreate(Sender: TObject);
    procedure FormShow(Sender: TObject);
    procedure StringGrid2SelectCell(Sender: TObject; ACol, ARow: Integer;
      var CanSelect: Boolean);
    procedure StringGrid1DblClick(Sender: TObject);
    procedure StringGrid2DblClick(Sender: TObject);
    procedure SpeedButton2Click(Sender: TObject);
    procedure SpeedButton1Click(Sender: TObject);
  private
    { Private declarations }

  public
    { Public declarations }
    FQuery:TQuery;
    FDbGRid:TwwDBGrid;
    procedure DeleteRow(Row:integer;StringGrid: TStringGrid);
    Function GetFieldName(FindName:string):string;
    Function GetKeyFieldName(FindName:string):string;
  end;
  procedure P_OtherSort( Query:TQuery;DbGRid:TwwDBGrid);
var
  OtherSortFrm: TOtherSortFrm;

implementation

{$R *.DFM}
procedure P_OtherSort( Query:TQuery;DbGRid:TwwDBGrid);
var dlg:TOtherSortFrm;
begin
    if not Dbgrid.DataSource.DataSet.Active then exit;
    dlg:=TOtherSortFrm.Create(nil);
    dlg.FDbgrid:=DBGrid;
    dlg.FQuery:=Query;
    dlg.ShowModal;
end;

procedure TOtherSortFrm.FormCreate(Sender: TObject);
begin
    StringGrid1.Cells[0,0]:='   序號';
    StringGrid1.Cells[1,0]:='      字段名';
    StringGrid2.Cells[0,0]:='   序號';
    StringGrid2.Cells[1,0]:='      字段名';
    StringGrid2.Cells[2,0]:='排序條件';
end;

procedure TOtherSortFrm.FormShow(Sender: TObject);
var i:integer;
    RNum:integer;
    str:string;
begin
   for i:=0 to FDbGrid.GetColCount -2 do
   begin
     //和奇怪的事情,如果傳入的grid為繼成的窗體的FDbGrid.Fields[0]出錯
     try
       str:=FDbGrid.Fields[i].KeyFields;
     except
       continue;
     end;
     if (FDbGrid.Fields[i].FieldKind = fkData) or (FDbGrid.Fields[i].FieldKind = fkLookup) then
     begin
        //判斷是否還是查找字段
        if (FDbGrid.Fields[i].FieldKind = fkLookup) then
        begin
           str:=FDbGrid.Fields[i].KeyFields;
           if FDbGrid.DataSource.DataSet.FieldByName(str).FieldKind = fkLookup then continue;
        end;

        if StringGrid1.Cells[0,1]='' then RNum:=1
        else
        begin
          RNum:=StringGrid1.RowCount;
          StringGrid1.RowCount:=StringGrid1.RowCount + 1;
        end;
        StringGrid1.Cells[0,RNum]:=inttostr(RNum);
        StringGrid1.Cells[1,RNum]:=trim(FDbGrid.Columns[i].DisplayLabel);
     end;
   end;
end;

procedure TOtherSortFrm.DeleteRow(Row:integer;StringGrid: TStringGrid);
var i:integer;
begin
    //大于2時要刪除行
    if StringGrid.RowCount > 2 then
    begin
       for i:=Row to StringGrid.RowCount - 1 do
       begin
          //行移動
          StringGrid.Rows[i]:=StringGrid.Rows[i+1];
       end;
       StringGrid.RowCount:=StringGrid.RowCount - 1;
    end
    else StringGrid.Rows[row].Clear;

end;
procedure TOtherSortFrm.StringGrid2SelectCell(Sender: TObject; ACol,
  ARow: Integer; var CanSelect: Boolean);
var RNum:integer;
begin
   //當單擊第三列時改變升降序
   if ACol = 2 then
   begin
       if StringGrid2.Cells[0,ARow]='' then exit;

       if StringGrid2.Cells[2,ARow]='↑' then StringGrid2.Cells[2,ARow]:='↓'
       else StringGrid2.Cells[2,ARow]:='↑' ;
   end;
end;

procedure TOtherSortFrm.StringGrid1DblClick(Sender: TObject);
var RNum:integer;
begin
    if StringGrid1.Cells[0,1]='' then exit;
    //雙擊時移動行
    if StringGrid2.Cells[0,1]='' then RNum:=1
    else
    begin
       RNum:=StringGrid2.RowCount;
       StringGrid2.RowCount:=StringGrid2.RowCount + 1;
    end;
    StringGrid2.Cells[0,RNum]:=StringGrid1.Cells[0,StringGrid1.row];
    StringGrid2.Cells[1,RNum]:=StringGrid1.Cells[1,StringGrid1.row];
    StringGrid2.Cells[2,RNum]:='↑';
    DeleteRow(StringGrid1.row,StringGrid1);
end;

procedure TOtherSortFrm.StringGrid2DblClick(Sender: TObject);
var RNum:integer;
begin
   if StringGrid2.col = 2 then exit;
   //雙擊時移動行
   if StringGrid2.Cells[0,1]='' then exit;
   if StringGrid1.Cells[0,1]='' then RNum:=1
   else
   begin
      RNum:=StringGrid1.RowCount;
      StringGrid1.RowCount:=StringGrid1.RowCount + 1;
   end;
   StringGrid1.Cells[0,RNum]:=StringGrid2.Cells[0,StringGrid2.row];
   StringGrid1.Cells[1,RNum]:=StringGrid2.Cells[1,StringGrid2.row];
   DeleteRow(StringGrid2.row,StringGrid2);
end;

procedure TOtherSortFrm.SpeedButton2Click(Sender: TObject);
begin
  ModalResult:=mrCancel;
end;
Function TOtherSortFrm.GetFieldName(FindName:string):string;
var i:integer;
begin
   for i:=0 to FDbGrid.GetColCount -2 do
   begin
     if trim(FDbGrid.Columns[i].DisplayLabel) = FindName then
     begin
        result:= FDbGrid.Columns[i].FieldName;
        break;
     end;
   end;
end;
Function TOtherSortFrm.GetKeyFieldName(FindName:string):string;
var i:integer;
begin
   result:='';
   for i:=0 to FDbGrid.GetColCount -2 do
   begin
     if trim(FDbGrid.Columns[i].DisplayLabel) = FindName then
     begin
        result:= FDbGrid.Fields[i].KeyFields;;
        break;
     end;
   end;
end;
procedure TOtherSortFrm.SpeedButton1Click(Sender: TObject);
var FOrder:string;
    i:integer;
    str:string;
    p:integer;
    FieldName:string;
begin
    if StringGrid2.Cells[0,1] ='' then exit;
    FOrder:=' ORDER BY ';
    for i:=1 to StringGrid2.RowCount - 1 do
    begin
       FieldName:=GetFieldName(StringGrid2.Cells[1,i]);
       //判斷是否是查找字段
       if FDbGrid.DataSource.DataSet.FieldByName(FieldName).FieldKind = fkLookup then
         FOrder:=FORder + GetKeyFieldName(StringGrid2.Cells[1,i])
       else
         FOrder:=FORder + FieldName;
         
       if StringGrid2.Cells[2,i] = '↑' then FOrder:=FORder+' ASC,'
       else FOrder:=FORder+' DESC,';
    end;
    Forder:=Copy(Forder,0,length(Forder)-1);//去掉最后的','
    str:=StrUpper(pchar(FQuery.SQL.Text));
    str:=copy(str,0,length(str)-2);
    p:=pos('ORDER BY',str);
    if p>0 then str:=copy(str,0,p-1);
    FQuery.DisableControls;
    FQuery.close;
    FQuery.sql.Text:=str+FOrder;
    FQuery.open;
    FQuery.EnableControls;
    ModalResult:=mrok;
end;

end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美日韩一区二区三区在线观看| 99在线精品视频| 欧美一区二区三区在线观看| 热久久免费视频| 精品黑人一区二区三区久久| 国产精品18久久久久久久久久久久| 久久久精品国产99久久精品芒果| 成人av综合在线| 一区二区久久久久| 欧美一级生活片| 国产一区二区精品久久91| 国产欧美日本一区二区三区| 91福利视频网站| 麻豆国产一区二区| 国产精品久久久久久亚洲伦| 欧美吻胸吃奶大尺度电影 | 136国产福利精品导航| 色综合久久久久网| 日韩激情视频网站| 中文一区二区在线观看| 91麻豆国产福利在线观看| 亚洲444eee在线观看| 精品免费一区二区三区| 成人动漫一区二区| 奇米888四色在线精品| 中文字幕欧美区| 7777精品伊人久久久大香线蕉经典版下载| 久久91精品国产91久久小草| 亚洲免费观看高清完整版在线观看| 精品99999| 99国产精品久| 美美哒免费高清在线观看视频一区二区| www久久精品| 在线精品视频小说1| 韩国视频一区二区| 亚洲一区二区三区四区五区中文| 久久综合久久99| 欧美另类久久久品| 成人午夜激情片| 久久99蜜桃精品| 亚洲成人午夜电影| 综合久久久久久久| 久久久久久久精| 欧美日韩国产精品成人| jizz一区二区| 国产一二精品视频| 婷婷激情综合网| 亚洲乱码国产乱码精品精可以看| 2023国产精品自拍| 91麻豆精品国产91久久久资源速度| 不卡电影免费在线播放一区| 精品午夜一区二区三区在线观看| 香蕉久久一区二区不卡无毒影院| 国产精品成人午夜| 国产性天天综合网| 精品久久久久久综合日本欧美 | 欧美一区二区三区四区五区| 99久久精品国产麻豆演员表| 国产成人99久久亚洲综合精品| 日本麻豆一区二区三区视频| 香蕉成人啪国产精品视频综合网| ●精品国产综合乱码久久久久| 国产日韩欧美制服另类| 日韩欧美一级片| 欧美一区二区在线不卡| 欧美日韩国产另类不卡| 欧美日韩你懂的| 欧美色国产精品| 欧美日韩第一区日日骚| 欧美日韩一区高清| 欧美日韩高清一区二区三区| 欧美色图12p| 欧美精品v国产精品v日韩精品| 欧美日韩国产一级片| 欧美日韩国产高清一区二区| 欧美日韩在线亚洲一区蜜芽| 欧美日韩国产首页在线观看| 欧美日韩国产精品成人| 69堂成人精品免费视频| 91麻豆精品国产无毒不卡在线观看| 欧美精品在线一区二区三区| 欧美一区午夜视频在线观看| 日韩三级免费观看| 精品99999| 中文字幕va一区二区三区| 中文字幕中文字幕中文字幕亚洲无线| 国产精品久久久99| 亚洲国产一区视频| 免费视频一区二区| 国产精品亚洲一区二区三区妖精 | 91麻豆精东视频| 欧美性受xxxx| 日韩欧美二区三区| 久久久天堂av| 亚洲人成伊人成综合网小说| 亚洲国产精品尤物yw在线观看| 日本欧美一区二区| 国产精品91xxx| 在线观看欧美精品| 日韩午夜在线观看| 国产女人aaa级久久久级| 136国产福利精品导航| 亚洲一区二区三区三| 伦理电影国产精品| 91在线精品一区二区三区| 欧美性生活一区| 久久久久久毛片| 亚洲最色的网站| 精品亚洲国产成人av制服丝袜 | 国产精品一区专区| 色婷婷av一区二区三区大白胸| 91精品久久久久久久99蜜桃| 国产蜜臀av在线一区二区三区| 一区二区三区在线观看视频| 日韩电影在线观看一区| 丰满放荡岳乱妇91ww| 欧美日韩一区精品| 欧美国产日韩亚洲一区| 视频在线观看91| 色综合色综合色综合色综合色综合| 日韩一区二区三区电影在线观看| 国产精品第五页| 精品亚洲成av人在线观看| 在线视频你懂得一区| 久久九九影视网| 日本不卡免费在线视频| 99久久久国产精品| 精品国产乱码久久久久久老虎| 亚洲精品亚洲人成人网 | 中文字幕一区二区三区精华液| 视频一区视频二区中文| 色综合中文字幕国产| 9191精品国产综合久久久久久| 中文一区二区在线观看| 老司机精品视频导航| 欧美日韩一区二区三区高清 | 在线一区二区观看| 国产片一区二区| 久久精品国产澳门| 欧美丝袜自拍制服另类| 国产精品不卡视频| 国产成人av一区| 久久综合视频网| 蜜臀91精品一区二区三区| 欧美日韩美少妇 | 亚洲综合视频在线观看| 国产传媒日韩欧美成人| 日韩欧美精品在线视频| 日本成人在线看| 欧美日韩在线不卡| 亚洲制服丝袜一区| 色成人在线视频| 亚洲精品国产无天堂网2021| 99久久99久久精品国产片果冻| 国产精品色哟哟| 色又黄又爽网站www久久| 亚洲欧洲日韩综合一区二区| 国产成人免费在线观看| 久久亚洲综合av| 韩国三级在线一区| 精品成人a区在线观看| 久久国产婷婷国产香蕉| 精品欧美一区二区久久| 另类小说欧美激情| 精品av久久707| 国产精品18久久久久久久久 | 日韩视频在线观看一区二区| 婷婷国产v国产偷v亚洲高清| 欧美精品 国产精品| 天堂资源在线中文精品| 91精品国产综合久久精品图片| 奇米色一区二区| 久久综合九色综合欧美98| 国产乱对白刺激视频不卡| 欧美极品aⅴ影院| 99vv1com这只有精品| 伊人色综合久久天天人手人婷| 在线免费观看日本欧美| 日韩精品电影在线观看| 2021中文字幕一区亚洲| 国产精品亚洲视频| 国产精品女同互慰在线看 | 欧美日韩一区二区在线观看视频| 性做久久久久久久免费看| 日韩欧美国产电影| 国产精品1区二区.| 亚洲狠狠丁香婷婷综合久久久| 欧美日韩成人综合| 极品尤物av久久免费看| 国产精品无人区| 在线观看国产91| 另类的小说在线视频另类成人小视频在线 | 91女厕偷拍女厕偷拍高清| 亚洲国产精品久久久男人的天堂| 欧美一区二区三区在线观看| 国产99久久久久久免费看农村| 一区二区国产视频| 日韩免费视频一区二区| zzijzzij亚洲日本少妇熟睡| 亚洲成人av免费|