Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.11.14;
Скачать: CL | DM;

Вниз

Проблема проверки добавляемого значения.   Найти похожие ветки 

 
S!D ©   (2002-10-26 12:53) [0]

Проблема проверки добавляемого значения.
Есть таблица Table1, связанный с ее индексированным полем DBEdit1.
Необходимо перед обновлением произвести проверку присутствия или отсутствия в этом поле введенного значения (DBEdit1.Text).
Приведенный ниже код не работоспособен.
Буду признателен, если подкините решение данной проблемы и/или объясните в чем ошибка.

procedure TForm1.DataSource1UpdateData(Sender: TObject);
begin
if Table1.FindKey([DBEdit1.Text]) then
begin
...


 
Anatoly Podgoretsky ©   (2002-10-26 13:01) [1]

Как проявляется не работоспособность?


 
S!D ©   (2002-10-26 14:50) [2]

Debugger Exception Notification

Project raised exception class EStackOverFlow W/message "Stack overflow"
причем при трассировке видно что прога зацикливается с if на begin приведенного кода


 
S!D ©   (2002-10-26 14:52) [3]

.. т.е begin процедуры.


 
MsGuns ©   (2002-10-26 17:05) [4]

Естественно, она и ДОЛЖНА циклить. Что ж ты в событии, возникающем ПЕРЕД тем как постировать изменения, пытаешься покинуть ИЗМЕНЕННУЮ запись ?
Проверка на дублирование ключей должна ИМХО выполняться в событии OnKeyViolate (точнее, не проверка, а собственно реакция на повтор ключа) - никаких доп.поисков при этом не требуется.

Искать надо если поле не есть ключ или уникальный индекс и другим методом - LookUp, который ищет повторяемость, НЕ ПОКИДАЯ текущую запись.
К событиям TDataSource надо вообще относиться очень осторожно, хорошо понимая суть и последовательнось реакции отдельных составляющих программы (источника, отображателя, физ.НД и т.д.)


 
S!D ©   (2002-10-26 20:21) [5]

И правда, чего это я?
спасибо за вправку извилин! :)



Страницы: 1 вся ветка

Текущий архив: 2002.11.14;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.026 c
7-46159
vitnt2000
2002-09-13 07:11
2002.11.14
Событие по прерывания железа


14-46117
Шишкин Илья
2002-10-27 13:36
2002.11.14
3DMax!!!


1-45967
werr
2002-11-04 14:45
2002.11.14
сортировка


14-46138
Anatoly Podgoretsky
2002-10-28 08:49
2002.11.14
Именинники 28 октября


3-45692
Cossys
2002-10-17 16:11
2002.11.14
TTable.Locate по двум полям???