Форум по 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,029
Версия 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,029
Версия 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,029
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

1. Проверку CanModify надо вызывать до вызова Edit.
2. Свойство ReadOnly случаем не установлено?
Ответить с цитированием
  #7  
Старый 16.02.2009, 17:13
WinnyThePooh WinnyThePooh вне форума
Прохожий
 
Регистрация: 16.02.2009
Сообщения: 31
Репутация: 10
По умолчанию

1. Про CanModify - спасибо, не знал (но, надеюсь, это не меняет состояния базы?).
2. ReadOnly = false

И вот ещё: эта проблема не с одной таблицей, а почти со всеми, хотя, некоторое время назад её не было. Возникла, имхо, после момента, когда начал создавать код по взаимным проверкам между таблицами (ну типа, читаем данные в одной - правим в другой). Но стараюсь везде перед контролем все post'ить...

P.S. Про теги - прошу прощения, в будущем учту? (ну НОВИЧОК я )

Последний раз редактировалось WinnyThePooh, 16.02.2009 в 17:46.
Ответить с цитированием
  #8  
Старый 18.02.2009, 20:04
WinnyThePooh WinnyThePooh вне форума
Прохожий
 
Регистрация: 16.02.2009
Сообщения: 31
Репутация: 10
Хорошо Источник проблем найден...

Спасибо всем, кто откликнулся на проблему!
Решение, как всегда, оказалось тривиальным и находилось в генокоде программиста
Функция RatePU408(ReportID) сносила Edit, т.к. в ней происходил поиск по Locate в базе, которую в Edit двумя строками ранее вызова функции перевели, и она, есс-но слетала опять в Browse.
Переход в Edit непосредственно перед присвоением (ну, точнее, после функции) сняло проблему.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter