Rambler's Top100
"Knowledge itself is power"
F.Bacon
Поиск | Карта сайта | Помощь | О проекте | ТТХ  
 Круглый стол
  
Правила КС
>> Настройки

Фильтр вопросов
>> Новые вопросы
отслеживать по
>> Новые ответы

Избранное

Страница вопросов
Поиск по КС


Специальные проекты:
>> К л ю к в а
>> Г о л о в о л о м к и

Вопрос №

Задать вопрос
Off-topic вопросы

Помощь

 
 К н и г и
 
Книжная полка
 
 
Библиотека
 
  
  
 


Поиск
 
Поиск по КС
Поиск в статьях
Яndex© + Google©
Поиск книг

 
  
Тематический каталог
Все манускрипты

 
  
Карта VCL
ОШИБКИ
Сообщения системы

 
Форумы
 
Круглый стол
Новые вопросы

 
  
Базарная площадь
Городская площадь

 
   
С Л С

 
Летопись
 
Королевские Хроники
Рыцарский Зал
Глас народа!

 
  
ТТХ
Конкурсы
Королевская клюква

 
Разделы
 
Hello, World!
Лицей

Квинтана

 
  
Сокровищница
Подземелье Магов
Подводные камни
Свитки

 
  
Школа ОБЕРОНА

 
  
Арсенальная башня
Фолианты
Полигон

 
  
Книга Песка
Дальние земли

 
  
АРХИВЫ

 
 

Сейчас на сайте присутствуют:
 
  
 
Во Флориде и в Королевстве сейчас  21:14[Войти] | [Зарегистрироваться]
Ответ на вопрос № 83616

10-12-2018 14:24
Использую D2010 + FibPlus + Ehlib

простой вопрос по мастер-детейл.
на форме мастер и детальные таблицы
все настроено и работает на "УРА", но ситуация:

Пользователь изменил запись в детальной таблице,
(детальный датасет  сейчас state=dsEdit)
кликает на мастер таблице...

детальный датасет переоткривается,
все изменения теряются

ВОПРОС
——————————-
КАК ОТЛОВИТЬ такие действия
чтобы при изменении мастер записи не терялось редактирования в детальной таблице

как сделал/обошел я:
при событиях insert/update в детальной таблице делал дисейбл мастера,
при событии post в детальной таблице делал енейбл мастера

нутром чувствую что можно сделать как-то получше и прозрачно...

[+] Добавить в избранные вопросы

Отслеживать ответы на этот вопрос по RSS

Ответы:


Уважаемые авторы вопросов! Большая просьба сообщить о результатах решения проблемы на этой странице.
Иначе, следящие за обсуждением, возможно имеющие аналогичные проблемы, не получают ясного представления об их решении. А авторы ответов не получают обратной связи. Что можно расценивать, как проявление неуважения к отвечающим от автора вопроса.

16-12-2018 15:41 | Сообщение от автора вопроса
Коллега
просто гигантское вам СПАСИБО
я получил нужный функционал !!!

то что нужно !
//—————————————————————————————————————————————-
procedure Tform_Orders.fdsOrdersBeforeScroll(DataSet: TDataSet);
begin
  if (fdsPayments.State in [dsEdit, dsInsert])
  then begin
    MessageDlg('Спочатку потрібно завершити редагування !', mtWarning, [mbOK], 0);
    abort;
  end;
end;

14-12-2018 04:14
Попробуйте обработать событие TpFIBDataSet.BeforeScroll. Для примера, если tbTest2_det подчинённая таблица для tbTest1_mst, то:

procedure TdmMain.tbTest1_mstBeforeScroll(DataSet: TDataSet);
begin
  if (tbTest2_det.State in [dsEdit, dsInsert])
  then begin
    if (MessageDlg('Данные в режиме редактирования.'+#$D#$A+
            'отменить ввод?', mtConfirmation, [mbNo, mbOk], 0) = mrOk)
      then tbTest2_det.Cancel  //отменяем введённые данные
      //else tbTest2_det.Post; //подтверждаем данные и выполняем scroll
      else Abort;              //или отменяем scroll, оставаяь в dsEdit
    end;
end;



13-12-2018 07:02
спасибо за ответы,


Den Sarych:
флаг CanсelOnExit тру/фолс без разницы, ничего не меняется

BOB
да уверен. Триггеры БД все контролируют

13-12-2018 05:57 | Вопрос к автору: запрос дополнительной информации
Добрый день.
А Вы уверенны, что данные в детальной таблице необходимо 100% сохранить?
Вдруг пользователь "случайно" набрал "А" .....


11-12-2018 23:00 | Вопрос к автору: запрос дополнительной информации
>>>как сделал/обошел я: при событиях insert/update в детальной таблице делал дисейбл мастера
  Флаг dgCancelOnExit, по умолчанию включён в DBGridEh или DBGrid.Options, именно для того, что бы ненавязчиво (из уст пользователей) напомнить разработчику о том, что неплохо разработать хоть какую-то логику работы с "данными формы". Другими словами, задуматься как работает пользователь, а не только как хранятся данные в БД. И дать повод разработчику поразмышлять над тем, что будет, если пользователь: "не полностью заполнит поля" в компоненте или форме, перейдёт на другой компонент или форму не закончив редактирование, просто закроет программку не закончив редактирование данных.

11-12-2018 05:50
>>> кликает на мастер таблице ... детальный датасет переоткривается, все изменения теряются
  У TDBGridEh, так же как и у TDBGrid, есть свойство Options, а там флаг CanсelOnExit. Кроме того, у них же, есть событие onExit.

Добавьте свое cообщение

Вашe имя:  [Войти]
Ваш адрес (e-mail):На Королевстве все адреса защищаются от спам-роботов
контрольный вопрос:
Раз дощечка, два дощечка будет лесенка. Раз словечко, два словечко, будет ЧТО?
в качестве ответа на вопрос или загадку следует давать только одно слово в именительном падеже и именно в такой форме, как оно используется в оригинале.
Надоело отвечать на странные вопросы? Зарегистрируйтесь на сайте.
Тип сообщения:
Текст:
Жирный шрифт  Наклонный шрифт  Подчеркнутый шрифт  Выравнивание по центру  Список  Заголовок  Разделительная линия  Код  Маленький шрифт  Крупный шрифт  Цитирование блока текста  Строчное цитирование
  • вопрос Круглого стола № XXX

  • вопрос № YYY в тесте № XXX Рыцарской Квинтаны

  • сообщение № YYY в теме № XXX Базарной площади
  • обсуждение темы № YYY Базарной площади
  •  
     Правила оформления сообщений на Королевстве

    Страница избранных вопросов Круглого стола.
      
    Время на сайте: GMT минус 5 часов

    Если вы заметили орфографическую ошибку на этой странице, просто выделите ошибку мышью и нажмите Ctrl+Enter.
    Функция может не работать в некоторых версиях броузеров.

    Web hosting for this web site provided by DotNetPark (ASP.NET, SharePoint, MS SQL hosting)  
    Software for IIS, Hyper-V, MS SQL. Tools for Windows server administrators. Server migration utilities  

     
    © При использовании любых материалов «Королевства Delphi» необходимо указывать источник информации. Перепечатка авторских статей возможна только при согласии всех авторов и администрации сайта.
    Все используемые на сайте торговые марки являются собственностью их производителей.

    Яндекс цитирования