С Новым годом! Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/9: Рейтинг темы: голосов - 9, средняя оценка - 4.56
20 / 20 / 2
Регистрация: 26.01.2010
Сообщений: 106
1

Синхронизированное отображение данных в двух dbgrid-ах

23.02.2011, 10:55. Показов 1781. Ответов 8
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Всем доброго времени суток! Вопрос такой: есть бд, созданная в access. База состоит из двух таблиц:Customer и Account, которые отображаются на двух dbgrid-ах. В первой таблице перечисляются клиенты, во второй их аккаунты. Как сделать так, чтобы при наведении курсора мыши на имя клиента в первом dbgrid-е, во втором отображались данные из второй таблицы только для этого клиента?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
23.02.2011, 10:55
Ответы с готовыми решениями:

Отображение данных в DBGrid из двух и более TpFIBDataSet'ов
Доброго времени суток =) вопрос такой.. как можно отобразить в DBGrid данные из двух и более...

Отображение данных в DBGrid
привет всем. подскажите пожалуйста. почему когда в делфи создаю связь между таблицами(access), то...

Отображение данных в DBGrid
Как сделать подстановку в DBGrid(Рис.3 это то что мне нужно), чтоб отображалось не idZakaz (поле...

Отображение данных в DBGrid
Подскажите, пожалуйста, есть ли "человеческий" способ устранить такое неудобство? Есть форма на...

8
Почетный модератор
8784 / 2537 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
23.02.2011, 11:39 2
pir, фильтрами можно, можно настроить зависимость между источниками данных, можно с помощью запросов... попользуйтесь местным поиском, тут уже не раз такие проблемы рассматривались
1
20 / 20 / 2
Регистрация: 26.01.2010
Сообщений: 106
23.02.2011, 15:42  [ТС] 3
LordVoodoo, извините за глупый вопрос, но фильтры какого компонента Вы имеете ввиду?
0
1263 / 706 / 62
Регистрация: 21.12.2009
Сообщений: 2,256
23.02.2011, 17:57 4
Цитата Сообщение от pir Посмотреть сообщение
но фильтры какого компонента Вы имеете ввиду
У объектов типа TDataSet или у наследников есть свойство Filtered. Использование этого свойства и имел ввиду Lord_VooDoo
Это свойство удобно использовать вместе с обработчиком события OnFilterRecord, в котором задается условие фильтрации. Можно также использовать свойство Filter, но я не рекомендую это делать.
И, наконец, Lord_VooDoo Вам намекнул, что фильтрацию можно делать в запросе, формирующем набор данных. Для этого обычно исполдьзуется предикат WHERE в запросе SELECT
1
20 / 20 / 2
Регистрация: 26.01.2010
Сообщений: 106
23.02.2011, 20:58  [ТС] 5
Народ, помогите кодом кто сможет. весь вечер убил и никак не пойму как использовать OnFilterRecord для моей конкретной задачи:
Цитата Сообщение от pir Посмотреть сообщение
Вопрос такой: есть бд, созданная в access. База состоит из двух таблиц:Customer и Account, которые отображаются на двух dbgrid-ах. В первой таблице перечисляются клиенты, во второй их аккаунты. Как сделать так, чтобы при наведении курсора мыши на имя клиента в первом dbgrid-е, во втором отображались данные из второй таблицы только для этого клиента?
0
126 / 126 / 24
Регистрация: 14.02.2010
Сообщений: 289
23.02.2011, 21:36 6
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
procedure TForm1.IBTable1FilterRecord(DataSet: TDataSet;
  var Accept: Boolean);
begin
if  DataSet.FieldByName('STREETCD').Value= 3 then Accept:=true // строка отображается 
 else Accept:=False;  // строка скрыта
 
end;
 
procedure TForm1.Button1Click(Sender: TObject);
begin
IBTable1.Filtered:=true;
end;
вот примитивный пример!
1
20 / 20 / 2
Регистрация: 26.01.2010
Сообщений: 106
23.02.2011, 22:14  [ТС] 7
Цитата Сообщение от sanya0107 Посмотреть сообщение
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
procedure TForm1.IBTable1FilterRecord(DataSet: TDataSet;
  var Accept: Boolean);
begin
if  DataSet.FieldByName('STREETCD').Value= 3 then Accept:=true // строка отображается 
 else Accept:=False;  // строка скрыта
 
end;
 
procedure TForm1.Button1Click(Sender: TObject);
begin
IBTable1.Filtered:=true;
end;
вот примитивный пример!
sanya0107подобные , спасибо, но подобные примеры я находил, я не могу понять как реализовать механизм фильтрации в одном dbgrid-е при условии наведения курсора мыши на определенную запись во втором dbgride

Добавлено через 1 минуту
Цитата Сообщение от sanya0107 Посмотреть сообщение
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
procedure TForm1.IBTable1FilterRecord(DataSet: TDataSet;
  var Accept: Boolean);
begin
if  DataSet.FieldByName('STREETCD').Value= 3 then Accept:=true // строка отображается 
 else Accept:=False;  // строка скрыта
 
end;
 
procedure TForm1.Button1Click(Sender: TObject);
begin
IBTable1.Filtered:=true;
end;
вот примитивный пример!
sanya0107, спасибо, но подобные примеры я находил, я не могу понять как реализовать механизм фильтрации в одном dbgrid-е при условии наведения курсора мыши на определенную запись во втором dbgride
0
126 / 126 / 24
Регистрация: 14.02.2010
Сообщений: 289
23.02.2011, 22:22 8
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
var
  Form1: TForm1;
  s:Variant;
 
implementation
 
{$R *.dfm}
 
procedure TForm1.DBGrid1CellClick(Column: TColumn);
begin
s:=IBTable1.FieldValues['STREETCD'];
IBTable1.Filtered:=true;
 
end;
 
procedure TForm1.IBTable1FilterRecord(DataSet: TDataSet;
  var Accept: Boolean);
begin
if DataSet.FieldByName('STREETCD').Value=s then Accept:=true
 else Accept:=false;
end;
вот так можно!
0
Почетный модератор
8784 / 2537 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
23.02.2011, 23:35 9
pir,
Цитата Сообщение от pir Посмотреть сообщение
но фильтры какого компонента Вы имеете ввиду?
в дбгридах большая часть операций происходит с источниками данных, т.к. дбгрид в сущности только данные отображает, а все манипуляции происходят с источниками данными, которые вы указываете в TDataSource
0
23.02.2011, 23:35
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
23.02.2011, 23:35
Помогаю со студенческими работами здесь

DBGrid отображение данных
Привет всем . Подскажите пожалуйста как сделать в DBGrid чтоб отображалась полностью таблица а не...

Отображение данных в DBGrid
Всем привет! Небольшая проблема в следующем: Есть две формы. На одной DBGrid, отображающий данные...

Отображение данных DBGrid
procedure TDataOutput.Execute; begin inherited; Synchronize(UpdateDBGrid); ...

Отображение данных в DBGrid
Здравствуйте, у меня есть программа, к ней подключена база данных (SQL). В одной таблице я заношу...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru