-
Добрый день. Имеется связка: MySQL + mysqlconnector + (TADODataSet + TDataSetProvider) + TClientDataSet. В свойствах провайдера UpdateMode = upWhereKeyOnly. Как в ADODataSet так и в ClientDataSet созданы наборы статичных полей. Для ключевых полей ProviderFlags указаны [pfInWhere,pfInKey], для остальных - [pfInUpdate]. Это как для ADO, так и для ClientDataSet. При работе с набором данных вроде бы все в порядке, НО: если перевести датасет в режим редактирования, стереть в DBEdit значение поля, затем повторить его -> Post -> при ApplyUpdates(0) получаю ошибку "Record not found or changed by another user." - почему, и что сделать? В остальном все в порядке: редактирование, вставка, удаление..гуглю заколебал, полей типа дата/время с миллисекундами в наборе нет. На данный момент режим однопользовательский. Заранее благодарен за помощь.
-
Довольно распространеннаяя проблема. Решается не всегда легко. Скорее всего у Вас нередактируемый запрос, слишком сложный с вычисляемыми полями и неоднозначными связями. Самое надежное - упростить запрос. Проверить наличие в запросе ключевых полей всех связанных таблиц В Проперти "Unique table" указать одну таблицу http://www.delphikingdom.ru/asp/viewitem.asp?catalogid=420
-
> Нат (29.07.08 10:57) [1]
Ты писатель, это видно сразу. Мог бы для разнообразия и почитать. Например, эту фразу "В остальном все в порядке: редактирование, вставка, удаление.."
-
запросы простые...вот например: таблица CREATE TABLE IF NOT EXISTS users
(UserName VARCHAR(40) NOT NULL,
UserPwd VARBINARY(40) NOT NULL,
FirstName VARCHAR(40),
LastName VARCHAR(40),
EmailAddress VARCHAR(40),
PhoneNumber VARCHAR(32),
IsActive BOOLEAN NOT NULL DEFAULT 1,
IsSuspended BOOLEAN NOT NULL DEFAULT 0,
CONSTRAINT pk_users PRIMARY KEY (UserName),
CONSTRAINT ck_UserPwd CHECK (LENGTH(UserPwd) > 6)
) ENGINE=MyISAM DEFAULT CHARSET=latin1; запрос в ADODataSet SELECT u.* ,
CASE u.IsActive
WHEN 0 THEN 'No'
WHEN 1 THEN 'Yes'
END AS IsActiveText,
CASE u.IsSuspended
WHEN 0 THEN 'No'
WHEN 1 THEN 'Yes'
END AS IsSuspendedText
FROM users u
-
чему равно dataset.ChangeCount ? проверяешь перед ApplyUpdate ?
-
ChangeCount = 1 (редактируется по 1 записи на форме).
-
в обработчике OnReconcileError, при перехвате стандартным HandleReconcileError, видно, что все поля, кроме изменяемого, имеют значение <Unchanged> в ModifiedValue, а изменяемое поле имеет одно и то же значение, как в ModifiedValue, так и в OriginalValue.
-
dataset.Delta <> nil ?
-
VarIsNull(DataSet.Delta), VarIsEmpty(DataSet.Delta) = False
|