Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2003.08.28;
Скачать: [xml.tar.bz2];

Вниз

MIDAS, ReconcileError и ClientDataSet.Append   Найти похожие ветки 

 
Nikolay M.   (2003-08-04 10:48) [0]

Назрел такой концептуальный вопрос.
В тонком клиенте есть форма редактирования чего-либо, скажем, аквариумных рыбок. При попытке добавить новую запись с неуникальным названием рыбки возникает ошибка на уровне БД (уникальный индекс), которая обрабатывается в обработчике ReconcileError и выдается сообщение пользователю.
Как можно красиво сделать откат ApplyUpdate-а в этом случае? Закрывать окно - грубо, там может быть много введенных данных. Если в ReconcileError делать Action := raCancel и тп, ClientDataSet выходит из режима вставки.
Единственное, что пока пришло в голову - это делать при возникновении ошибки в ReconcileError что-то вроде

Field1ErrorValue := CDS.Fields[0].Value;
...
Field10ErrorValue := CDS.Fields[9].Value;


А на кнопке ОК в форме редактирования делать:

if (CDS.ApplyUpdates (-1) > 0) then
begin
CDS.Append;
CDS.Fields[0].Value := Field1ErrorValue;
...
CDS.Fields[9].Value := Field10ErrorValue;
end;


Или поиграться с Delta, но все равно красотой, имхо, такой вариант не блещет :(
Делать
Action := HandleReconcileError(DataSet, UpdateKind, E);
тоже не очень хочется.


 
Соловьев   (2003-08-04 10:56) [1]


> ошибка на уровне БД (уникальный индекс),

а зачем давать пользователи редактировать уникальный индекс?


 
Nikolay M.   (2003-08-04 10:59) [2]


> а зачем давать пользователи редактировать уникальный индекс?



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



 
Соловьев   (2003-08-04 11:29) [3]

уникальный индекс с неуникальным названием рыбки - это как? :)


 
Nikolay M.   (2003-08-04 11:40) [4]

Разжевываю.
Название рыбки должно быть уникально? Да, чтобы разные юзеры не заводили одинаковых рыбок и из-за этого не возникли дубли по названию. Для этого нужен уникальный индекс по полю "название рыбки".
Btw, редактировать индекс пользователю никто не разрешает, доступно редактирование значений поля, которые должны быть уникально, причем уникальность обеспечивается UNIQUE INDEX-ом по этому полю.


 
Соловьев   (2003-08-04 12:08) [5]

raCorrect Replace the current updated record with the value of the record in the event handler.


 
Nikolay M.   (2003-08-04 12:16) [6]

Я умею читать хелп :)
В любом случае 10Х за беспокойство :)



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

Форум: "Базы";
Текущий архив: 2003.08.28;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.005 c
14-92182
VEG
2003-08-11 13:12
2003.08.28
Эта ветка для моих тестов!!!


14-92242
лсдишник
2003-08-09 19:15
2003.08.28
Помогите выьрать LCD 17


4-92320
nester
2003-06-26 19:17
2003.08.28
Как выгрузить чужую dll-ну? shdoclc.dll


14-92220
Daniel
2003-08-10 12:29
2003.08.28
Процессоры AMD относятся к семейству х86?


14-92249
Омлет
2003-08-09 00:30
2003.08.28
Palladin, с днём рождения!





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский