0 / 0 / 0
Регистрация: 13.11.2011
Сообщений: 30

Правильное использование условного оператора

07.09.2012, 10:20. Показов 1052. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Надо сделать так чтобы программа выдавала сообщение сроки лицензии в порядке. Я сделал вот так но так получается что сообщение выдается столько раз сколько записей в таблице. Куда правльнее поставиить условный оператор else?
Привожу код.
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
var d:integer;
begin
DM.Query1.Close;
DM.Query1.SQL.Text:='SELECT * FROM PO';
DM.Query1.Open;
while not DM.Query1.Eof
  do
  begin
  d:=DM.Query1.FieldByName('End_date').AsVariant-now;
  if d<=45
    then ShowMessage('Срок лицензии для программы '+DM.Query1.FieldByName('Name_program').AsString+' закончится через '+IntToStr(d)+' дней');
    DM.Query1.Next;
  end else Showmessage('Сроки лицензии в порядке!')
 
end;
 
end.
Надо сделать так чтобы программа выдавала сообщение сроки лицензии в порядке. Я сделал вот так но так получается что сообщение выдается столько раз сколько записей в таблице. Куда правльнее поставиить условный оператор else?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.09.2012, 10:20
Ответы с готовыми решениями:

Задание на использование условного оператора.
ТЕМА :УСЛОВНЫЙ ОПЕРАТОР ЗАДАНИЕ Составьте программу, которая решает поставленную в вашем варианте задачу. Программа должна: отображать...

Программирование с помощью условного оператора и оператора выбора
Нужно решить две задачи. 1. Даны три числа. Определить является ли сумма каких-либо из них положительной. Указание к выполнению:...

Правильное использование переменных
Всем Ку) Читаю муны и почти везде юзают,на мой взгляд лишние переменные. Например Ts:tstringlist; S:string; ... // Зачем ...

6
Почетный модератор
 Аватар для Puporev
64319 / 47615 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
07.09.2012, 10:27
Может так?
Delphi
1
2
3
4
5
6
7
while not DM.Query1.Eof do
 begin
  d:=DM.Query1.FieldByName('End_date').AsVariant-now;
  if d<=45 then ShowMessage('Срок лицензии для программы '+DM.Query1.FieldByName('Name_program').AsString+' закончится через '+IntToStr(d)+' дней')
  else Showmessage('Сроки лицензии в порядке!');
  DM.Query1.Next;
 end
0
0 / 0 / 0
Регистрация: 13.11.2011
Сообщений: 30
07.09.2012, 10:31  [ТС]
Не подходит: все равно выдает столько сообщений сколько записей в таблице
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33421 / 21527 / 8240
Регистрация: 22.10.2011
Сообщений: 36,935
Записей в блоге: 12
07.09.2012, 10:41
Цитата Сообщение от Ericnex Посмотреть сообщение
Куда правльнее поставиить условный оператор else?
Здесь else - вообще не решение.
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
good := true; // переменная типа boolean;
while not DM.Query1.Eof do
begin
   d:=DM.Query1.FieldByName('End_date').AsVariant-now;
   if d<=45 then
   begin
      good := false; // Уже не всё нормально, одна лицензия заканчивается
      ShowMessage('Срок лицензии для программы '+DM.Query1.FieldByName('Name_program').AsString+
         ' закончится через '+IntToStr(d)+' дней');
   end;
   DM.Query1.Next;
end;
 
// Только после просмотра всех значений можно говорить, всё ли в порядке
if good then Showmessage('Сроки лицензии в порядке!');
1
0 / 0 / 0
Регистрация: 13.11.2011
Сообщений: 30
07.09.2012, 10:58  [ТС]
Как то подвисает у меня программа: ничего не выдает
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
procedure TForm3.Button8Click(Sender: TObject);
var d:integer;
good:boolean;
begin
DM.Query1.Close;
DM.Query1.SQL.Text:='SELECT * FROM PO';
DM.Query1.Open;
good:=true;
while not DM.Query1.Eof
  do
  begin
  d:=DM.Query1.FieldByName('End_date').AsVariant-now;
  if d<=45 then
    begin
    good:=false;
     ShowMessage('Ñðîê ëèöåíçèè äëÿ ïðîãðàììû '+DM.Query1.FieldByName('Name_program').AsString+ ' íà ñåðâåðå ' + DM.Query1.FieldByName('Name_server').AsString + ' çàêîí÷èòñÿ ÷åðåç '+IntToStr(d)+' äíåé');
    DM.Query1.Next;
  end;
  end;
   if good then Showmessage('Ñðîêè ëèöåíçèè â ïîðÿäêå');
end;
end.
0
4195 / 1841 / 223
Регистрация: 06.10.2010
Сообщений: 4,127
07.09.2012, 10:58
Надо в запросе условие задавать. Как-нибудь так что-ли
Delphi
1
'SELECT * FROM PO WHERE End_date-NOW<=45'
0
0 / 0 / 0
Регистрация: 13.11.2011
Сообщений: 30
07.09.2012, 11:08  [ТС]
Вру. Все заработало. Код неправильно переписал.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.09.2012, 11:08
Помогаю со студенческими работами здесь

Правильное использование указателей на процедуры без параметров
с указателем на вложенные процедуры переменные главной процедуры читаются не верно! Как заставить корректно видеть переменные без...

Использование оператора XOR
Есть функция которая преобразует текст: function XORText(text:string):string; var key, longkey : string; i : integer; toto: char; ...

Правильное использование принтера
Если кто знает, то, пожалуйста, помогите!!! Я написал программу и не знаю как толком выводить на принтер с предварительным просмотром и т....

Использование условного оператора внутри цикла for
помогите пожалуйста разобраться int main(){ int i=49; for(int n=0; n&lt;99; n++){ array=1; // вот тут что будет...

Использование условного оператора после операторов цикла с условием
Дана последовательность целых чисел, оканчивающаяся числом -1. Количество чисел в последовательности не меньше двух. Определить, есть ли в...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru