Показать сообщение отдельно
  #1  
Старый 08.12.2013, 14:42
sAVe sAVe вне форума
Прохожий
 
Регистрация: 20.06.2013
Сообщения: 40
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию указатель в DataSet

Всем привет!
Всё воюю с указатель в DataSet'е.
Нужно чтоб после изменения он оставался на выбранной записи в DBGrid'е, но в текущем примере он почему-то после выполнения процедуры перемещается на самую последнюю запись в таблице.
В чём проблема?
Код:
procedure TEdit_Office.add_officeClick(Sender: TObject);
var
curs: integer;
begin
try
with DataModule1.IBQuery2 do
   begin
    SQL.Text:='UPDATE office SET o_name = :o_name WHERE o_id = :o_id';
    ParamByName ('o_name').AsString:=Edit1.Text;
    ParamByName ('o_id').Value := DataModule1.office.FieldByName('o_id').AsString;

    DataModule1.DataSource1.DataSet.RecNo:= curs;
    curs:= DataModule1.office.FieldByName('o_id').AsInteger;

    Transaction.StartTransaction;
    ExecSQL;
    Transaction.Commit;
    Transaction.Active:=false;

   end;
   DataModule1.OFFICE.Close;
   DataModule1.OFFICE.Open;

   DataModule1.DataSource1.DataSet.Locate('o_id', IntToStr (curs), []);

   except
   on E: Exception do
   begin
    if DataModule1.IBQuery2.Active then
      DataModule1.IBQuery2.Transaction.Rollback;
    Application.MessageBox(PChar(E.Message), 'Îøèáêà', MB_ICONERROR);
   end;
   end;

   Edit_Office.close;
end;
Ответить с цитированием