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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 01.07.2013, 16:45
aquatell aquatell вне форума
Прохожий
 
Регистрация: 21.04.2011
Сообщения: 31
Репутация: 10
По умолчанию Изменение данных в AdoQuery

Всем привет.
Есть таблица выборка данных через AdoQuery, редактирую я через DBGrid но изменения внесенные ячейку не фиксируются пока я не перейду на другую ячейку.
Как сделать так чтобы изменения фиксировались когда фокус ввода редактирования исчез, например когда жму клавишу Enter и когда мышкой кликаю еще раз по этой ячейке.
Т.к. какое событие происходит после завершения редактирования ячейки DBGRID и почему не происходит автоматическая фиксация?

Вообще идея у меня такая - есть два файла формата DBF в одном находится справочник номенклатура, в другом у меня база. Есть две формы, в первой редактирую, а из второй в модальном режиме выбираю эту номенклатуру. Выборка делаю через SELECT, а далее редактирую данные через DBGRID и информация напрямую записывается в файл базы, но с кликами по другой ячейке, чтобы записалось значение в первой это заморочка.
Заранее благодарен.

Последний раз редактировалось aquatell, 01.07.2013 в 17:21.
Ответить с цитированием
  #2  
Старый 01.07.2013, 17:02
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

Запросами все в базе редактируется.
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
Ответить с цитированием
  #3  
Старый 01.07.2013, 17:13
aquatell aquatell вне форума
Прохожий
 
Регистрация: 21.04.2011
Сообщения: 31
Репутация: 10
По умолчанию

Цитата:
Сообщение от M.A.D.M.A.N.
Запросами все в базе редактируется.
Это я знаю, но у меня получается через Insert и EDIT и если мышкой перехожу на другую ячейку. Что то с фокусом, может его автоматически как то переводить надо или устанавливать. Есть какие нибудь идеи?
Ответить с цитированием
  #4  
Старый 01.07.2013, 18:19
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

на onclose формы поставь это
Код:
if dbGrid1.EditorMode or DBGrid1.DataSource.DataSet.Modified then DBGrid1.DataSource.DataSet.Post;
то есть если ввел в гриде и не щелкнул по другой строке и вышел - введенные данные сохранятся
можешь кинуть на нажатии enter
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")
Ответить с цитированием
  #5  
Старый 01.07.2013, 19:10
aquatell aquatell вне форума
Прохожий
 
Регистрация: 21.04.2011
Сообщения: 31
Репутация: 10
По умолчанию

Цитата:
Сообщение от Mrak
на onclose формы поставь это
Код:
if dbGrid1.EditorMode or DBGrid1.DataSource.DataSet.Modified then DBGrid1.DataSource.DataSet.Post;
то есть если ввел в гриде и не щелкнул по другой строке и вышел - введенные данные сохранятся
можешь кинуть на нажатии enter

Закинул я на обработчик onStateChange в DataSource все отработало на ура.
Код:
procedure TDM.DBFdsStateChange(Sender: TObject);
begin
with mainForm do
begin
DBGrid1.DataSource.DataSet.Edit;
if dbGrid1.EditorMode or DBGrid1.DataSource.DataSet.Modified then
DBGrid1.DataSource.DataSet.Post;
end;
end;
БОЛЬШОЕ СПАСИБО!
Ответить с цитированием
  #6  
Старый 01.07.2013, 19:56
Аватар для Mrak
Mrak Mrak вне форума
Местный
 
Регистрация: 26.01.2013
Адрес: МО
Сообщения: 438
Версия Delphi: XE2
Репутация: 17
По умолчанию

пожалуйста) но мне приятнее когда на кнопочку нажимают
она вон там -------->
__________________
Я за здоровый экстрим!
Спасибо за "спасибо")

Последний раз редактировалось Mrak, 02.07.2013 в 14:31.
Ответить с цитированием
Этот пользователь сказал Спасибо Mrak за это полезное сообщение:
aquatell (01.07.2013)
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter