Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 06.09.2010, 18:45
jaxik jaxik вне форума
Прохожий
 
Регистрация: 06.09.2010
Сообщения: 11
Репутация: 10
По умолчанию БД

Есть БД, написанная в Database Desktkop. База автомобилей.

В программе (например, при нажатии на кнопку) выполняется
цикл по всем транспортным средствам в БД. Если у какого-то
т/с наступило время прохождения ТО (т.е. его текущий пробег
равен или превышает пробегу для прохождения ТО и ранее ТО не
проводилось), то данное т/с как-то помечается (цветом, или выводится
в отдельную таблицу).


Как это возможно сделать? И чем лучше всего воспользоваться?
Ответить с цитированием
  #2  
Старый 06.09.2010, 20:27
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Смотрите в сторону запросов и если вывод идет в стандартный TDBGrid то в сторону события OnDrawDataCell
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 07.09.2010, 13:20
jaxik jaxik вне форума
Прохожий
 
Регистрация: 06.09.2010
Сообщения: 11
Репутация: 10
По умолчанию

Получилось что я сделал для ТО-1, всё прекрасно выделяет и работает. Но а как можно сделать для ТО-2, ТО-3?

Где 1500 это километраж до 1-ого ТО.

Цитата:
procedure TForm1.DBGrid1DrawColumnCell(Sender : TObject; const Rect: TRect;
DataCol: Integer; Column: TColumn; State: TGridDrawState);
begin
if dm.table1.fieldbyname('ТО-1').AsVariant=false then
WITH DBGrid1.Canvas DO
BEGIN
IF gdSelected IN State THEN
BEGIN
Font.Color:=clHighlightText;
Brush.Color:=clHighlight
END
ELSE
BEGIN
Font.Color:=clBlack;
if dm.table1.FieldByName('Пробег (км)').AsInteger>1500
THEN
Brush.Color:=clLime
else
Brush.Color:=DBGrid1.Color;
END;
WITH Rect.TopLeft DO
TextRect(Rect, X+2, Y+2, Column.Field.AsString);
END

end;

Я бы мог конечно откопировать этот алгоритм три раза, но это как то неправильно будет.
Ответить с цитированием
  #4  
Старый 07.09.2010, 15:06
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Дайте структуру таблицы и несколько записей для примера.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #5  
Старый 07.09.2010, 15:13
jaxik jaxik вне форума
Прохожий
 
Регистрация: 06.09.2010
Сообщения: 11
Репутация: 10
По умолчанию

---Машина---Номер---Пробег (км)---ТО1---ТО2---ТО3.
BMW X6 ххх 1500 False False False
Lexus RX ТТТ 3421 True False False
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 16:52.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter