Тема: ADODataSet.Locate
Показать сообщение отдельно
  #2  
Старый 14.03.2008, 16:44
Аватар для mav_c
mav_c mav_c вне форума
Активный
 
Регистрация: 26.03.2007
Адрес: Москва
Сообщения: 287
Репутация: 30
По умолчанию

Цитата:
Сообщение от Terio
Подскажите пожалуйста, как сделать так, чтобы ADODataSet.Locate не обнуляла сделанные изменения.
Поясню на примере: на форме размещены ADOConnection, ADODataSet, DataSource, DBGridEh (из Ehlib) и одна кнопка.
Используется MS SQL Server, в базе одна таблица с полями: Cod (int), Name(char), Flag(bit).
В запросе ADODataSet: Select * From Table1
Изменения напрямую в БД запрещены.
На кнопке:

Код:
procedure TForm1.Button1Click(Sender: TObject);
var i:integer;
begin
i:=5;
ADODataSet1.Locate('Cod',i,[]);
DBGridEh1.Columns.Items[2].Field.NewValue:='True';
ADODataSet1.Locate('Cod',i+1,[]);
end;


Если закоментировать предпоследнюю строчку, все нормально, но как только применяем Locate, все сделанные изменения сбрасываются
Может есть какой-то другой способ перейти на нужную строку в таблице?

Всё правильно. Ты переходишь с помощью locate на другую запись, а изменения не постишь!

А почему нельзя так ADODataSet.FieldByName('Flag').AsInteger := 1;
ADODataSet.Post();
__________________
---------------------------------------------
Программирование - не профессия, а стиль жизни
Ответить с цитированием