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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 08.03.2011, 06:52
gebs gebs вне форума
Прохожий
 
Регистрация: 03.08.2010
Сообщения: 48
Репутация: 10
По умолчанию событие на добавление записи в DbGrid

Здравствуйте. Встала задача оповещать при добавлении записи в наборе данных представлением которых занимается DBGridEh. Используются следующие компоненты: MyQuery, MyDataSource.
Вопрос: как это сделать есть идея с RecordCount. Но как программно это сделать я не знаю, мб кто-нибудь посоветует или подскажет?
Спасибо.
Ответить с цитированием
  #2  
Старый 08.03.2011, 14:33
Assistant Assistant вне форума
Продвинутый
 
Регистрация: 20.02.2011
Адрес: там где правят идиоты
Сообщения: 603
Версия Delphi: 7
Репутация: выкл
По умолчанию

используй событие OnAfterPost или OnAfterInsert в MyQuery
Ответить с цитированием
  #3  
Старый 08.03.2011, 16:42
gebs gebs вне форума
Прохожий
 
Регистрация: 03.08.2010
Сообщения: 48
Репутация: 10
По умолчанию

Цитата:
Сообщение от Assistant
используй событие OnAfterPost или OnAfterInsert в MyQuery
Мне нужно немного другое: если в гриде добавилаь запись, то на это событие программа должна как то реагировать. вышеперечисленные события - не то.
Ответить с цитированием
  #4  
Старый 08.03.2011, 19:04
stil stil вне форума
Новичок
 
Регистрация: 24.11.2010
Сообщения: 91
Репутация: 41
По умолчанию

DBGrid только отображает данные и все ни коем образом не связывается с базой данных. Посмотри события у DBGrid ты найдешь только отрисовку, нажатия на заголоку, получение/потеря фокуса. Это происходит через Query, Table. Поэтому работай напрямую с источником данных, в твоем случае MyQuery.
Ответить с цитированием
  #5  
Старый 09.03.2011, 09:32
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

при добавлении записи в TDBGrid выводится вопрос "Отменить добавление?":
Код:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Grids, DBGrids, DB, DBTables;

type
  TForm1 = class(TForm)
    DataSource1: TDataSource;
    Table1: TTable;
    DBGrid1: TDBGrid;
    procedure FormCreate(Sender: TObject);
    procedure Table1AfterInsert(DataSet: TDataSet);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.FormCreate(Sender: TObject);
begin
  Table1.AfterInsert:=Table1AfterInsert;
end;

procedure TForm1.Table1AfterInsert(DataSet: TDataSet);
begin
  if MessageBox(Handle, 'Отменить добавление?', 'Вопрос',
  MB_OKCANCEL or MB_ICONQUESTION)=IDOK then Table1.Cancel;
end;

end.
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
  #6  
Старый 09.03.2011, 15:48
gebs gebs вне форума
Прохожий
 
Регистрация: 03.08.2010
Сообщения: 48
Репутация: 10
По умолчанию

Хм, поясняю, по таймеру делаю обновление записей раз в 5 минут, рефреш не подходит. Если 1 пользователь добавил данные в таблицу, то у другого по прошествии 5 минут должен проиграться звук. Как это сделать?
Ответить с цитированием
  #7  
Старый 10.03.2011, 02:57
gebs gebs вне форума
Прохожий
 
Регистрация: 03.08.2010
Сообщения: 48
Репутация: 10
По умолчанию

Всем спасибо разобрался, считаем кодичество записей по RecordCount и если изменяется производим нужное действие.
Ответить с цитированием
  #8  
Старый 10.03.2011, 08:40
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

а если "другой" пользователь за эти 5 минут удалил и добавил запись?
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
  #9  
Старый 10.03.2011, 10:26
Assistant Assistant вне форума
Продвинутый
 
Регистрация: 20.02.2011
Адрес: там где правят идиоты
Сообщения: 603
Версия Delphi: 7
Репутация: выкл
По умолчанию

Цитата:
Сообщение от NumLock
а если "другой" пользователь за эти 5 минут удалил и добавил запись?
зачем ты человека в тупик вводишь ))
Ответить с цитированием
  #10  
Старый 10.03.2011, 10:39
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Как уже сказали, по RecordCount не вариант, кроме того пользователь может вводить одну запись часами, так-что вам придется обрабатывать состояние набора данных самостоятельно. Как я понял у вас не серверное приложение, т.е. централизовано следить за изменением данных некому, тогда у вас каждая из копий программы должна писать в некий лог/файл что такой-то клиент делает с такой-то таблицей и такой-то записью и она-же должна читать из этого файла эти данные.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #11  
Старый 10.03.2011, 10:51
Аватар для NumLock
NumLock NumLock вне форума
Let Me Show You
 
Регистрация: 30.04.2010
Адрес: Северодвинск
Сообщения: 5,426
Версия Delphi: 7, XE5
Репутация: 59586
По умолчанию

а почему бы по udp, к примеру, не оповещать "остальных" о проделаных изменениях?
__________________
Пишу программы за еду.
__________________
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter