Показать сообщение отдельно
  #2  
Старый 08.12.2013, 16:52
Аватар для poli-smen
poli-smen poli-smen вне форума
Профессионал
 
Регистрация: 06.08.2012
Адрес: Кривой Рог
Сообщения: 1,791
Версия Delphi: Delphi 7, XE2
Репутация: 4415
По умолчанию

Цитата:
Сообщение от sAVe
Всем привет!
Всё воюю с указатель в 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 - в ней сейчас находится мусор и ты этот мусор зачем-то записываешь в RecNo.

Да и дальше у тебя какая-то путаница - сохраняешь в curs значение из "DataModule1.office", а восстанавливаешь из "DataModule1.DataSource1.DataSet". Если это одно и то же может лучше прийти к одному варианту, чтобы самому же потом и не путаться?
Ответить с цитированием