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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 24.11.2011, 15:45
Progermc Progermc вне форума
Прохожий
 
Регистрация: 24.11.2011
Сообщения: 3
Репутация: 10
По умолчанию стаж работы

Всем доброго времени суток,
помогите мне пожалуйста.
задача такова:
необходимо рассчитать стаж работника в базе данных, я написал код для 2х дат, с момента прихода и даты сегодня, но переменная хранит только одно значения, помогите сделать для n'ного количества работников.
код прилагаю.


Код:
procedure TForm1.ADOTable1CalcFields(DataSet: TDataSet);
var
d1,d2: TDateTime;

n{счётчик дней итого}, year{кол-во лет без остатка},
m{счётчик месяцев},day{дни}, month{месяцы} : integer;

begin

// начальная дата из таблицы
d1:= StrToDate(ADOTable1.FieldByName('Стаж работы на').Value);
// сегодняшняя дата
d2:= Date;

Days.Text:=IntToStr(DaysBetween(d1,d2));//вычисляем ИТОГО дней
// присваиваем дни переменной
n:=StrToInt(Days.Text);
// узнаем сколько лет
year:=n div 365;
// сколько месяцев
m:=n-(year*365);

// если дней больше то определяем кратность след. месяца
if m>=30 then begin {1}
month:=m div 30;
day:=m mod 30;

end    {1} else day:=m;

// выводим количество стажа в таблицу
ADOTable1.FieldByName('Stazh').Value := IntToStr(year)+' лет '+IntToStr(month)+
' месяцев '+IntToStr(day)+' дней';

// условия о выработке лет
if (year = 3) and (month = 0) and (day = 0) then ShowMessage('3 года работы');
if (year = 10) and (month = 0) and (day = 0) then ShowMessage('10 лет работы');
if (year = 20) and (month = 0) and (day = 0) then ShowMessage('20 лет работы');

end;

я знаю что єто нужно реализовать при помощи массивов, но голова уже не работает..
извините за беспокойства

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

Че-то я не догоняю что вы хотите. У вас идет расчет на текущего работника. Причем тут n-количество работников? Вы хотите получить итог по вычисляемому столбцу?
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 24.11.2011, 16:44
Progermc Progermc вне форума
Прохожий
 
Регистрация: 24.11.2011
Сообщения: 3
Репутация: 10
По умолчанию

если в базе данных 1 запись, в которой есть только один работник, то все отлично работает, но если добавить 2го работника, оно выдает ошибку при добавлении, добавление делаю через TEdit'ы -

если отключить код, и добавить данные о еще одном работнике, потом включить блок кода, все работает..
не знаю по чему..

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

Все очень просто. В момент добавления записи значение ADOTable1.FieldByName('Стаж работы на').Value еще null и как следствие попытка вычислить стаж порождает ошибку. Простейшее решение, это заключить блок кода в секцию try except end. Тогда будет так:
Код:
procedure TForm1.ADOTable1CalcFields(DataSet: TDataSet);
var
d1,d2: TDateTime;

n{счётчик дней итого}, year{кол-во лет без остатка},
m{счётчик месяцев},day{дни}, month{месяцы} : integer;

begin
try
// начальная дата из таблицы
d1:= StrToDate(ADOTable1.FieldByName('Стаж работы на').Value);
// сегодняшняя дата
d2:= Date;

Days.Text:=IntToStr(DaysBetween(d1,d2));//вычисляем ИТОГО дней
// присваиваем дни переменной
n:=StrToInt(Days.Text);
// узнаем сколько лет
year:=n div 365;
// сколько месяцев
m:=n-(year*365);

// если дней больше то определяем кратность след. месяца
if m>=30 then begin {1}
month:=m div 30;
day:=m mod 30;

end    {1} else day:=m;

// выводим количество стажа в таблицу
ADOTable1.FieldByName('Stazh').Value := IntToStr(year)+' лет '+IntToStr(month)+
' месяцев '+IntToStr(day)+' дней';

// условия о выработке лет
if (year = 3) and (month = 0) and (day = 0) then ShowMessage('3 года работы');
if (year = 10) and (month = 0) and (day = 0) then ShowMessage('10 лет работы');
if (year = 20) and (month = 0) and (day = 0) then ShowMessage('20 лет работы');
except
end;
end;
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #5  
Старый 24.11.2011, 17:16
Progermc Progermc вне форума
Прохожий
 
Регистрация: 24.11.2011
Сообщения: 3
Репутация: 10
По умолчанию

я не догадался обработать исключительную ситуацию, спасибо вам большое. =) выручили
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter