Поиск:

Ответ в темуСоздание новой темы Создание опроса
> запрос на выборку, с несколькими параметрами 
V
    Опции темы
malayka
Дата 17.6.2010, 22:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



добрый вечер!
Код

datamodule1.adoquery1.sql.Clear;
datamodule1.adoquery1.SQL.add('select Отделения.Отделение, Специальности.Специальность, Группы.Группа, Студент.Фамилия, Студент.Имя, Студент.Отчество, Студент.кодстудента,Студент.ДатаРождения, Студент.Мобильник');
datamodule1.adoquery1.SQL.add('FROM (Отделения INNER JOIN Специальности ON Отделения.КодОтделения = Специальности.КодОтделения) INNER JOIN (Группы INNER JOIN Студент ON Группы.КодГруппы = Студент.КодГруппы) ON Специальности.КодСпециальности = Группы.КодСпециальности');
datamodule1.adoquery1.SQL.add('where группы.группа ='+#39+DBLookupComboBox1.Text+#39);
datamodule1.adoquery1.SQL.add('and студент.фамилия ='+#39+Edit1.Text+#39);
datamodule1.adoquery1.SQL.add('and студент.имя ='+#39+Edit2.Text+#39);
datamodule1.adoquery1.SQL.add('and студент.отчество ='+#39+Edit3.Text+#39);
datamodule1.adoquery1.open;


вот данный запрос находит результат только в том случае, если все параметры совпадут, а если вместо and брать or, параметры работают по отдельности, тоже не вариант. вот как сделать, чтобы ввел, допустим, 2 значения, и выбирались бы только те записи, в которых эти значения имеются??
PM MAIL   Вверх
Akella
Дата 17.6.2010, 22:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

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



так проверяй, что и куда ввёл пользователь и строй запрос динамически, в чем проблема.
PM MAIL   Вверх
malayka
Дата 17.6.2010, 22:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



 smile 
PM MAIL   Вверх
malayka
Дата 17.6.2010, 23:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



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

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



надеюсь я вас правильно понял)
Код

datamodule1.adoquery1.sql.Clear;
datamodule1.adoquery1.SQL.add('select Отделения.Отделение, Специальности.Специальность, Группы.Группа, Студент.Фамилия, Студент.Имя, Студент.Отчество, Студент.кодстудента,Студент.ДатаРождения, Студент.Мобильник');
datamodule1.adoquery1.SQL.add('FROM (Отделения INNER JOIN Специальности ON Отделения.КодОтделения = Специальности.КодОтделения) INNER JOIN (Группы INNER JOIN Студент ON Группы.КодГруппы = Студент.КодГруппы) ON Специальности.КодСпециальности = Группы.КодСпециальности');
datamodule1.adoquery1.SQL.add('where группы.группа='+#39+DBLookupComboBox1.Text+#39);
if edit1.Text<>'' then
datamodule1.adoquery1.SQL.add('and студент.фамилия=' +#39+edit1.Text+#39);
datamodule1.adoquery1.open;


так вроде пашет
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.1562 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


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

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