Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #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;
Ответить с цитированием
  #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". Если это одно и то же может лучше прийти к одному варианту, чтобы самому же потом и не путаться?
Ответить с цитированием
  #3  
Старый 08.12.2013, 19:19
sAVe sAVe вне форума
Прохожий
 
Регистрация: 20.06.2013
Сообщения: 40
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Цитата:
Сообщение от poli-smen
[/code]Вот здесь ты используешь неинициализированную переменную curs - в ней сейчас находится мусор и ты этот мусор зачем-то записываешь в RecNo.

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


Да вот именно, что я тут уже намудрил...
Может пример покажешь?
Ответить с цитированием
  #4  
Старый 08.12.2013, 19:42
Аватар для poli-smen
poli-smen poli-smen вне форума
Профессионал
 
Регистрация: 06.08.2012
Адрес: Кривой Рог
Сообщения: 1,791
Версия Delphi: Delphi 7, XE2
Репутация: 4415
По умолчанию

Цитата:
Сообщение от sAVe
Да вот именно, что я тут уже намудрил...
Может пример покажешь?
Для начала убери эту вредоносную строку в которой идёт запись мусора в RecNo и проверь будет ли после этого прыгать на последнюю запись.

Ну а о замене "DataModule1.office" на "DataModule1.DataSource1.DataSet" (или наоборот) это только в том случае если это у тебя действительно одно и то же, да и то необязательно - только для большей понятности кода.
Ответить с цитированием
Этот пользователь сказал Спасибо poli-smen за это полезное сообщение:
sAVe (08.12.2013)
  #5  
Старый 08.12.2013, 22:22
sAVe sAVe вне форума
Прохожий
 
Регистрация: 20.06.2013
Сообщения: 40
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Цитата:
Сообщение от poli-smen
Для начала убери эту вредоносную строку в которой идёт запись мусора в RecNo и проверь будет ли после этого прыгать на последнюю запись.

Ну а о замене "DataModule1.office" на "DataModule1.DataSource1.DataSet" (или наоборот) это только в том случае если это у тебя действительно одно и то же, да и то необязательно - только для большей понятности кода.

Спасибо, разобрался!
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 14:39.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025