Цитата:
Сообщение от 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". Если это одно и то же может лучше прийти к одному варианту, чтобы самому же потом и не путаться?