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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #16  
Старый 06.03.2012, 14:56
Andrew_MSK Andrew_MSK вне форума
Прохожий
 
Регистрация: 25.11.2011
Сообщения: 28
Репутация: 10
Смех

Код:
procedure TDataModule1.ZQuery_rabzona1BeforePost(DataSet: TDataSet);
begin
  with DataModule1.ZQuery_rabzona1 do
  begin
  FieldByName('REGLAMENT').AsString:= FieldByName('REGLAM_RAB').AsString+' '
  +FieldByName('ELECTROMONTER').AsString+' '+FieldByName('INGENER').AsString+' '
  +FieldByName('REGLAMENT').AsString;
  end;

end;

так тоже работает и дополняет данные к существующему значению!!!!!
УРРРРААААААААА!!!!!
Ответить с цитированием
  #17  
Старый 06.03.2012, 15:05
Andrew_MSK Andrew_MSK вне форума
Прохожий
 
Регистрация: 25.11.2011
Сообщения: 28
Репутация: 10
По умолчанию

но при каждой записи формы.... он добавляет значения в поле....
нужно сделать что-то типа
Код:
if FieldByName('REGLAMENT').IsNull=False then
для всех трех полей....
Ответить с цитированием
  #18  
Старый 06.03.2012, 15:06
Andrew_MSK Andrew_MSK вне форума
Прохожий
 
Регистрация: 25.11.2011
Сообщения: 28
Репутация: 10
Восклицание

но при каждой записи формы.... он добавляет значения в поле....
нужно сделать что-то типа
Код:
if FieldByName('REGLAMENT').IsNull=False then
для всех трех полей....
чтобы данные добавлялись только в случае изменения dbedit.....
Ответить с цитированием
  #19  
Старый 06.03.2012, 15:32
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

проверяй изменились ли поля:
Код:
if Table1.FieldByName('ELECTROMONTER').OldValue<>Table1.FieldByName('ELECTROMONTER').NewValue then
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
Этот пользователь сказал Спасибо NumLock за это полезное сообщение:
Andrew_MSK (11.03.2012)
  #20  
Старый 06.03.2012, 16:44
Andrew_MSK Andrew_MSK вне форума
Прохожий
 
Регистрация: 25.11.2011
Сообщения: 28
Репутация: 10
Сообщение

Цитата:
Сообщение от NumLock
проверяй изменились ли поля:
Код:
if Table1.FieldByName('ELECTROMONTER').OldValue<>Table1.FieldByName('ELECTROMONTER').NewValue then

не работает (не добавляет данные, хотя меняю даты)
Код:
procedure TDataModule1.ZQuery_rabzona1BeforePost(DataSet: TDataSet);
begin
  with DataModule1.ZQuery_rabzona1 do
  begin
   if FieldByName('REGLAM_DATE').OldValue<>FieldByName('REGLAM_DATE').NewValue then
      with  DataModule1.ZQuery_rabzona1 do
   begin
      FieldByName('REGLAMENT').AsString:= FieldByName('REGLAM_RAB').AsString+' '
     +FieldByName('ELECTROMONTER').AsString+' '+FieldByName('INGENER').AsString+' '
     +FieldByName('REGLAM_DATE').AsString+' '+FieldByName('REGLAMENT').AsString+';';
   end;

  end;
end;
Ответить с цитированием
  #21  
Старый 06.03.2012, 19:23
Andrew_MSK Andrew_MSK вне форума
Прохожий
 
Регистрация: 25.11.2011
Сообщения: 28
Репутация: 10
По умолчанию

Цитата:
Сообщение от Andrew_MSK
не работает (не добавляет данные, хотя меняю даты)
отладчиком проверил что компонент beforpost не меняет значение поля...после его визуального изменения...
Код:
 o:= FieldByName('REGLAM_DATE').OldValue;
  n:= FieldByName('REGLAM_DATE').NewValue;
  if o <> n then
и o и n равные одной и той же дате, даже если я ее изменил...и нажал записать.....

есть варианты решения?????
Ответить с цитированием
  #22  
Старый 07.03.2012, 08:50
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

в BeforeEdit запоминать первоначальные значения полей. в BeforeInsert соотв. обнулять.
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
Этот пользователь сказал Спасибо NumLock за это полезное сообщение:
Andrew_MSK (11.03.2012)
  #23  
Старый 07.03.2012, 09:28
Andrew_MSK Andrew_MSK вне форума
Прохожий
 
Регистрация: 25.11.2011
Сообщения: 28
Репутация: 10
По умолчанию

Цитата:
Сообщение от NumLock
в BeforeEdit запоминать первоначальные значения полей. в BeforeInsert соотв. обнулять.
мне нужно сравнить значения в одном поле перед изменением и после...
значение перед изменением это то, что в БД, как поймать значение после изменения....
как сравнить эти два значения..когда они в разных процедурах???
я не знаю((( можно пример???
Ответить с цитированием
  #24  
Старый 07.03.2012, 09:49
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

Код:
type
  TForm1 = class(TForm)
    DataSource1: TDataSource;
    DBGrid1: TDBGrid;
    Table1: TTable;
    procedure Table1BeforePost(DataSet: TDataSet);
    procedure Table1BeforeEdit(DataSet: TDataSet);
  private
    { Private declarations }
    F0: String;

procedure TForm1.Table1BeforePost(DataSet: TDataSet);
begin
  if F0<>Table1.Fields[0].AsString then
    ShowMessage('<>');
end;

procedure TForm1.Table1BeforeEdit(DataSet: TDataSet);
begin
  F0:=Table1.Fields[0].AsString;
end;
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
Этот пользователь сказал Спасибо NumLock за это полезное сообщение:
Andrew_MSK (11.03.2012)
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter