![]() |
Модераторы: skyboy |
![]() ![]() ![]() |
|
velltar |
|
||||||
Новичок Профиль Группа: Участник Сообщений: 20 Регистрация: 24.9.2009 Репутация: нет Всего: нет |
Всем привет!
Народ помогите, реально завис на следующей проблеме и не знаю даже как в поиске набрать чтобы на путь истинный выйти ![]() Есть на удаленной машине база MySQL с такой таблицей
Так вот когда нужно вытащить например все записи у которых StoimostAgregat равен 1500 тут все как бы просто
А вот что делать и как построить запрос к базе данных если мне нужно вытянуть из базы данных записи построенные по фильтру, т.е. например в проге я выбрал типа вывести мне все агрегаты у которых есть фото и у которых стоимость 1500, а в другой раз выбрал например вывести все записи без описаний, но с фотографиями и стоимостью 2500 кпримеру. Как понимаете таким образом можно несметное кол-во комбинаций придумать в фильтре и тупо было бы под каждую мыслимую комбинацию писать отдельный запрос и ведь должно быть что то такое что бы помогло бы в этой ситуации. В частности можно былобы построить запрос в которой былибы перечисленны все критерии:
Но тогда возникает проблема - мне в данном случаи нужны записи в которых StoimostAgregat равен 1500 и DescrAgregat например 16980 (Это неважно ![]() Наверное можно сказать теперь проще - как создать динамическую строку запроса к базе данных в которую я сам включаю программно только те поля по которым хочу вести поиск? Надеюсь объяснил суть проблемы подробно. Сам новичек и не совсем может быть верно владею терминалогией ![]() Буду благодарен помощи старших товарищей. Всем заранее спасибо за помощь. Это сообщение отредактировал(а) velltar - 15.4.2010, 23:00 |
||||||
|
|||||||
Akina |
|
||||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Ошибка. См. тип данных в полях.
Динамически строить строку запроса, вставляя в неё только введённые условия отбора. Тема не имеет отношения к Visual Basic. Перенесено. -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
||||
|
|||||
FallFan |
|
||||||
![]() Шустрый ![]() Профиль Группа: Участник Сообщений: 83 Регистрация: 30.3.2008 Где: Санкт-Петербург Репутация: нет Всего: нет |
Решить проблему можно путем ввода в функции вида:
Данные в эту функцию поступают из формы поиска в VB, а сама функция проверят значения параметра и формирует строку запроса, т.е. напичкана операторами if:
Затем подставляется:
Также если, задуматься о расширяемости программы без переписывании кода, можно в качестве параметра функции вводить 2-мерный массив (Название поля, значение поля) Это сообщение отредактировал(а) FallFan - 16.4.2010, 08:04 |
||||||
|
|||||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Расширяемость НА КЛИЕНТЕ? эка ты хватил... я понимаю, предложить CREATE PROCEDURE/FUNCTION/VIEW с учётом (не)указывания условий отбора на сервере... Или речь об универсализации функции динамического построения условия отбора? -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
FallFan |
|
|||
![]() Шустрый ![]() Профиль Группа: Участник Сообщений: 83 Регистрация: 30.3.2008 Где: Санкт-Петербург Репутация: нет Всего: нет |
Речь идет об универсализации функции динамического построения условия отбора.
|
|||
|
||||
Zloxa |
|
||||
![]() Чо? ![]() ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 3473 Регистрация: 12.9.2008 Репутация: 33 Всего: 161 |
можно и без динамики, статикой.
Однако же следует понимать что автомобиль-амфибия, хоть и универсален, но все же едет хуже чем автомобиль и плавает хуже чем катер, а стоит больше чем оба вместе взятые. Универсализм отнюдь не всегда оправдан и на самом деле нужен. -------------------- Достоверно известно, что 89% людей доверяют статистике взятой с потолка ![]() |
||||
|
|||||
![]() ![]() ![]() |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | MySQL | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |