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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 16.02.2009, 15:41
WinnyThePooh WinnyThePooh вне форума
Прохожий
 
Регистрация: 16.02.2009
Сообщения: 31
Репутация: 10
Вопрос Проблема с переходом ADOTable в EDIT

Возникла проблема:
ADOTable не переходит в Edit по соответствующему методу. Предсостояние: dsBrowse.
В каком направлении надо искать причину?
Ответить с цитированием
  #2  
Старый 16.02.2009, 15:45
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,048
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

А ты указываешь там таблицу или вью?
А ошибку каку-нить выводит?
А записи есть? Если нету, то надо вызывать Insert или Append.
Ответить с цитированием
  #3  
Старый 16.02.2009, 16:27
WinnyThePooh WinnyThePooh вне форума
Прохожий
 
Регистрация: 16.02.2009
Сообщения: 31
Репутация: 10
По умолчанию

Указываю, ест-но, таблицу (кстати, забыл указать, что база Access2000 на локале).
Записи есть и перехожу в edit по результатам locate по ключевому полю.
Ошибку выдает после попытки присвоения значения полю: "Project X raised exception class EDatabaseError with message: ADOTableY: Dataset not in edit or insert mode" - что правильно, т.к. вывести его из browse не удается
Ответить с цитированием
  #4  
Старый 16.02.2009, 16:54
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,048
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Код сюда запости.
Ответить с цитированием
  #5  
Старый 16.02.2009, 16:58
WinnyThePooh WinnyThePooh вне форума
Прохожий
 
Регистрация: 16.02.2009
Сообщения: 31
Репутация: 10
По умолчанию

Ну вот что-то типа такого:

Код:
      ADOTablePU.first;
      if (ADOTablePU.Locate('idReport',ReportID,[])) then
      begin

        ADOTablePU.Edit;  //Переходим в режим редактирования

        if ADOTablePU.CanModify then
          begin
            iPU408:=RatePU408(ReportID);
            ADOTablePUitPU408.AsInteger:= iPU408;  //Здесь выдается ошибка!!!
            ADOTablePU.Post; //Запоминаем корректировку
            ADOTablePU.Edit; //Опять переходим в режим редактирования
          end;

lmikle: Где теги??? Голову оторву!!!

И ведь, зараза, проверку на CanModify преодолевает

Последний раз редактировалось WinnyThePooh, 16.02.2009 в 17:01.
Ответить с цитированием
  #6  
Старый 16.02.2009, 17:09
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,048
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

1. Проверку CanModify надо вызывать до вызова Edit.
2. Свойство ReadOnly случаем не установлено?
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter