Валентин Озеров - Советы по Delphi. Версия 1.4.3 от 1.1.2001

Здесь есть возможность читать онлайн «Валентин Озеров - Советы по Delphi. Версия 1.4.3 от 1.1.2001» весь текст электронной книги совершенно бесплатно (целиком полную версию без сокращений). В некоторых случаях можно слушать аудио, скачать через торрент в формате fb2 и присутствует краткое содержание. Жанр: Программирование, на русском языке. Описание произведения, (предисловие) а так же отзывы посетителей доступны на портале библиотеки ЛибКат.

Советы по Delphi. Версия 1.4.3 от 1.1.2001: краткое содержание, описание и аннотация

Предлагаем к чтению аннотацию, описание, краткое содержание или предисловие (зависит от того, что написал сам автор книги «Советы по Delphi. Версия 1.4.3 от 1.1.2001»). Если вы не нашли необходимую информацию о книге — напишите в комментариях, мы постараемся отыскать её.

…начиная с 1001. Смотрите другие файлы…

Советы по Delphi. Версия 1.4.3 от 1.1.2001 — читать онлайн бесплатно полную книгу (весь текст) целиком

Ниже представлен текст книги, разбитый по страницам. Система сохранения места последней прочитанной страницы, позволяет с удобством читать онлайн бесплатно книгу «Советы по Delphi. Версия 1.4.3 от 1.1.2001», без необходимости каждый раз заново искать на чём Вы остановились. Поставьте закладку, и сможете в любой момент перейти на страницу, на которой закончили чтение.

Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

end

Как заставить DBGrid сортировать данные по щелчку на заголовке столбца?

Nomadicсоветует:

Кyсочек кода, чтобы повесить на clickable столбец RxGrid, показывающий RxQuery с определенным макросом %Order. Работать не бyдет (без модyлей), но в качестве идеи может быть полезен.

unitvgRXutil;

interface

usesSysUtils, Classes, DB, DBTables, rxLookup, RxQuery;

{ TrxDBLookup }

procedureRefreshRXLookup(Lookup: TrxLookupControl);

procedureRefreshRXLookupLookupSource(Lookup: TrxLookupControl);

functionRxLookupValueInteger(Lookup: TrxLookupControl): Integer;

{ TRxQuery }

{ Applicatable to SQL's without SELECT * syntax }

{ Inserts FieldName into first position in '%Order' macro and refreshes query }

procedureHandleOrderMacro(Query: TRxQuery; Field: TField);

{ Sets '%Order' macro, if defined, and refreshes query }

procedureInsertOrderBy(Query: TRxQuery; NewOrder: String);

{ Converts list of order fields if defined and refreshes query }

procedureUpdateOrderFields(Query: TQuery; OrderFields: TStrings);

implementation

usesvgUtils, vgDBUtl, vgBDEUtl;

{ TrxDBLookup refresh }

typeTRXLookupControlHack = class(TrxLookupControl)

propertyDataSource;

propertyLookupSource;

propertyValue;

propertyEmptyValue;

end;

procedureRefreshRXLookup(Lookup: TrxLookupControl);

varSaveField: String;

begin

withTRXLookupControlHack(Lookup) do begin

SaveField := DataField;

DataField := '';

DataField := SaveField;

end;

end;

procedureRefreshRXLookupLookupSource(Lookup: TrxLookupControl);

varSaveField: String;

begin

withTRXLookupControlHack(Lookup) do begin

SaveField := LookupDisplay;

LookupDisplay := '';

LookupDisplay := SaveField;

end;

end;

functionRxLookupValueInteger(Lookup: TrxLookupControl): Integer;

begin

withTRXLookupControlHack(Lookup) do try

ifValue <> EmptyValue thenResult := StrToInt(Value)

elseResult := 0;

except

Result := 0;

end;

end;

procedureInsertOrderBy(Query: TRxQuery; NewOrder: String);

var

Param: TParam;

OldActive: Boolean;

OldOrder: String;

Bmk: TPKBookMark;

begin

Param := FindParam(Query.Macros, 'Order');

if notAssigned(Param) thenExit;

OldOrder := Param.AsString;

ifOldOrder <> NewOrder then begin

OldActive := Query.Active;

ifOldActive thenBmk := GetPKBookmark(Query, '');

try

Query.Close;

Param.AsString := NewOrder;

try

Query.Prepare;

except

Param.AsString := OldOrder;

end;

Query.Active := OldActive;

ifOldActive thenSetToPKBookMark(Query, Bmk);

finally

ifOldActive thenFreePKBookmark(Bmk);

end;

end;

end;

procedureUpdateOrderFields(Query: TQuery; OrderFields: TStrings);

varNewOrderFields: TStrings;

procedureAddOrderField(S: String);

begin

ifNewOrderFields.IndexOf(S) < 0 thenNewOrderFields.Add(S);

end;

var

I, J: Integer;

Field: TField;

FieldDef: TFieldDef;

S: String;

begin

NewOrderFields := TStringList.Create;

withQuery do try

forI := 0 toOrderFields.Count - 1 do begin

S := OrderFields[I];

Field := FindField(S);

ifAssigned(Field) and(Field.FieldNo > 0) thenAddOrderField(IntToStr(Field.FieldNo))

else try

J := StrToInt(S);

ifJ < FieldDefs.Count thenAddOrderField(IntToStr(J));

except

end;

end;

OrderFields.Assign(NewOrderFields);

finally

NewOrderFields.Free;

end;

end;

procedureHandleOrderMacro(Query: TRxQuery; Field: TField);

var

Param: TParam;

Tmp, OldOrder, NewOrder: String;

I: Integer;

C: Char;

TmpField: TField;

OrderFields: TStrings;

begin

Param := FindParam(Query.Macros, 'Order');

if notAssigned(Param) orField.Calculated orField.Lookup thenExit;

OldOrder := Param.AsString;

I := 0;

Tmp := '';

OrderFields := TStringList.Create;

try

OrderFields.Ad(Field.FieldName);

whileI < Length(OldOrder) do begin

Читать дальше
Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

Похожие книги на «Советы по Delphi. Версия 1.4.3 от 1.1.2001»

Представляем Вашему вниманию похожие книги на «Советы по Delphi. Версия 1.4.3 от 1.1.2001» списком для выбора. Мы отобрали схожую по названию и смыслу литературу в надежде предоставить читателям больше вариантов отыскать новые, интересные, ещё непрочитанные произведения.


Отзывы о книге «Советы по Delphi. Версия 1.4.3 от 1.1.2001»

Обсуждение, отзывы о книге «Советы по Delphi. Версия 1.4.3 от 1.1.2001» и просто собственные мнения читателей. Оставьте ваши комментарии, напишите, что Вы думаете о произведении, его смысле или главных героях. Укажите что конкретно понравилось, а что нет, и почему Вы так считаете.

x