Форум: "Базы";
Текущий архив: 2004.12.19;
Скачать: [xml.tar.bz2];
Вниз
Не удается избавиться от ошибки "Не удалось найти строку..." ADO Найти похожие ветки
← →
Aleksandr. (2004-11-22 14:12) [0]Таблица на MS SQL имеет одно из полей со значением по умолчанию. Соответственно, при редактировании через ADOQuery после Post возникает ошибка "Не удалось найти строку для обновления". Я этому ADOQuery на AfterOpen сделал
TADOQuery(DataSet).Properties["Update Resync"].Value:=adResyncAll
и все равно не помогает. Ключевое поле в таблице есть. Чем еще можно это лечить?
← →
Reindeer Moss Eater © (2004-11-22 15:26) [1]Ну а при чем здесь вообще поле со значением по умолчанию?
← →
Aleksandr. (2004-11-22 17:11) [2]Reindeer Moss Eater © :
Согласно описанию, если при изменениях опускаешь поле со значением по умолчанию, АДО может дать такую ошибку, т.к., например, поле2 в выражении попадает в WHERE Поле2=NULL,
а у сервера оно уже будет иметь значение по умолчанию.
← →
Reindeer Moss Eater © (2004-11-23 09:21) [3]Если у тебя в датасете есть экземпляр TField для этого поля, то ни о каком срабатывании DEFAULT констрейнта не может быть и речи.
← →
KSergey © (2004-11-23 09:56) [4]> [3] Reindeer Moss Eater © (23.11.04 09:21)
> Если у тебя в датасете есть экземпляр TField для этого поля,
> то ни о каком срабатывании DEFAULT констрейнта не может
> быть и речи.
Наглый обман трудового населения ;)
Скорее тогда уж зависит от MarshalOptions.
К стати, экземпляр TField после открытия DataSet есть всегда, согласитесь.
> Aleksandr. (22.11.04 14:12)
Дочитайте все 3 статьи
http://www.delphikingdom.com/asp/viewitem.asp?catalogid=408
Вообще - это шаманство чистейшей воды заставить ADO корректно все делать. Уж поверьте ;) Но можно ;)
← →
KSergey © (2004-11-23 09:58) [5]Да, забыл добавить: посоветовать что-то конкретное в таких случаях - нельзя. Только натурные эксперименты позволят подобрать приемлемое решение в конкретных условиях.
← →
Reindeer Moss Eater © (2004-11-23 10:06) [6]Если есть TField, до при вставке записи на сервер улетает insert, содержащий в списке полей поле TField.
(Кроме пожалуй случая c BDE + TUpdateSQL)
И дефолт значение у физ. поля отдыхает.
Не так?
Страницы: 1 вся ветка
Форум: "Базы";
Текущий архив: 2004.12.19;
Скачать: [xml.tar.bz2];
Память: 0.46 MB
Время: 0.03 c