Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как в ADOQuery менять fealds? 
V
    Опции темы
Riddik
Дата 30.5.2008, 00:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 598
Регистрация: 2.12.2006

Репутация: нет
Всего: нет



Вот в ADOQuery настоено в SQL некий запрос SELECT * FROM 'tablename'. И по двойному щелчку по компоненту сразу выбираешь, какие поля отображать в DBGrid.
Но в процессе работы пользователю  очень часто нужно в DBGrid вывести данные из другой таблицы или  произвести выборку из несколькиз таблиц. Как поменять SQL в ADOQuery - нашёл темы. Но как поменть отображаемые поля, (то окошечко, что выскакивает по двойном щелчке по компоненту ADOQuery)? 

Т.е., DBGrid связанн с ADoConnection, которая в свою очередь связано с ADOQuery. 
И нужно, чтобы при выборе конкретной строки в ComboBox в DBGrid выводился результат соответсвующего запроса, из нескольких таблиц. Как это всё менять в ADOQuery?
PM MAIL   Вверх
Fighter
Дата 30.5.2008, 01:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 810
Регистрация: 5.1.2005

Репутация: нет
Всего: 2



Во-первых DBGrid не связан с AdoConnection напрямую. Давай отбросим все программерские моменты, ты скажи еще раз и по подробнее, что требуется от программы. Пока что, что я понял, дык это то, чтобы в одном DBGrid можно было отображать содержимое разных таблиц, так? 
PM MAIL   Вверх
Данкинг
Дата 30.5.2008, 01:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Yersinia pestis
****


Профиль
Группа: Завсегдатай
Сообщений: 8302
Регистрация: 7.11.2006
Где: მოსკოვი

Репутация: 35
Всего: 130



Дык, из какой БД выбираешь - такие поля и отображаться в гриде (который привязан к запросу) будут.


--------------------
There's nothing left but silent epitaphs.
PM MAIL WWW   Вверх
Zmitro
Дата 30.5.2008, 08:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 32
Регистрация: 19.3.2008

Репутация: 1
Всего: 1



тогда для разных баз создай ADOConnection1 к одной базе и ADOConnection2 к другой, а в ADOQuery1 кодом меняй запрос и соединение.
примерно так:
Код

ADOQuery1.Close;
ADOQuery1.Connection := ADOConnection1; // или ADOConnection2
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM table1;'); // или table2
ADOConnection1.Connected := True;
ADOQuery1.Active := True; // или ADOConnection2

PM MAIL   Вверх
mrbrooks
Дата 30.5.2008, 08:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


трололомен
****


Профиль
Группа: Завсегдатай
Сообщений: 4259
Регистрация: 4.10.2006
Где: Дол Гулдур

Репутация: нет
Всего: 306



Цитата(Zmitro @ 30.5.2008,  08:05)
тогда для разных баз создай ADOConnection1 к одной базе и ADOConnection2 к другой, а в ADOQuery1 кодом меняй запрос и соединение.
примерно так:

А чем один ADOConnection не устраивает? Работаем только с ConnectionString
PM MAIL   Вверх
Riddik
Дата 30.5.2008, 08:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 598
Регистрация: 2.12.2006

Репутация: нет
Всего: нет



Fighter, да правильно!
База одна! Таблиц много. При том необходимо в DBGrid выводить результат запроа из разныз таблиц. Т.е. Первые два столбика из таблицы 1, а третий и четвёртый из таблицы 2 и т.д.  Потом наоборот. Разные комбинации.
Комбинировать вобщем.
PM MAIL   Вверх
Riddik
Дата 30.5.2008, 09:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 598
Регистрация: 2.12.2006

Репутация: нет
Всего: нет



Всё, вопрос решён!

Спасибо большое всем, большое спасибо!!!


Проблема просто возникала в том, что я зачем-то по двойному щелчку по ADOQuery добавлял поля из одной таблицы по умолчанию которая сразу появляется в DBGride. Поэтому при попытки сменить набор полей, отображаемых в DBGride, Делфи ругался, что не может найти указанные до этого поля. Я просто очистил их и всё!

Спасибо!
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.1036 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.