[函数]procedure SortDBGridEh(Sender: TObject; ACol: Integer; Column: TColumnEh);

王朝delphi·作者佚名  2006-01-09
宽屏版  字体: |||超大  

//

// 使用说明:单击DBGridEh的标题栏排序(适用于ADO)

// --在DBGridEh的事件OnTitleBtnClick引用该函数即可:

// SortDBGridEh(Sender, ACol, Column);

// --为了保证表格的每一列都能点击触发排序,你需要将你需要排序的列属性

// -- Title->TitleButton设置为True。

//

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;

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有