Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
1 / 1 / 0
Регистрация: 16.11.2009
Сообщений: 63

Набор параметров для SQL запроса

02.12.2013, 20:39. Показов 1907. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер. Требуется сделать фильтрацию таблицы по нескольким параметрам, набор и значения которых неизвестны заранее. Подскажите пожалуйста, как генерировать SQL запрос на лету в таком случае?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.12.2013, 20:39
Ответы с готовыми решениями:

Идентификация параметров SQL запроса в кострукторе
Пишу программу в VS2008, бд - Access, провайдер - Microsoft.Jet.OLEDB.4.0. Создаю файл набора данных DataSet1.xsd. Кидаю таблички с базы....

Напишите (консольную) программу, принимающую на вход имя файла и набор параметров. В зависимости от параметров программа должна работать в трёх режима
Вообщем такое же задание Добавлено через 2 минуты Напишите (консольную) программу, принимающую на вход имя файла и набор...

Дан произвольный треугольник АВС, для которого определен следующий набор характерных параметров
Помогите начинающему программисту!

15
1 / 1 / 0
Регистрация: 16.11.2009
Сообщений: 63
04.12.2013, 21:59  [ТС]
Неужто нет решения?
0
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
04.12.2013, 22:36
Структуру таблицы приведите.
0
1 / 1 / 0
Регистрация: 16.11.2009
Сообщений: 63
04.12.2013, 23:02  [ТС]
Таблица представляет собой логи с определенными параметрами: тип события, объект, время и.т.д.
Хочется сделать гибкий фильтр с возможностью фильтрации по разным наборам параметров, например: "события определенного типа" или "события определенного типа с определенным объектом в определенное время".
Неужто нужно прописывать все возможные комбинации параметров заранее?
0
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
04.12.2013, 23:08
Лучший ответ Сообщение было отмечено tezaurismosis как решение

Решение

Тогда как то так

SQL
1
2
3
4
5
6
7
SELECT  [category_id],
        [category_name],
        [color]
FROM    Categories
WHERE   (@category_id IS NULL OR [category_id] = @category_id OR @category_id < 0)
    AND (@category_name IS NULL OR [category_name] = @category_name)
    AND (@color IS NULL OR [color] = @color)
если значение есть передается значение иначе null
1
1 / 1 / 0
Регистрация: 16.11.2009
Сообщений: 63
04.12.2013, 23:18  [ТС]
А если, предположим, в базе будут пустые ячейки у некоторых записях. Разве они не окажутся в результате по критерию is null?
0
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
04.12.2013, 23:24
Данное условие отработает только если в поле будет значение NULL
1
1 / 1 / 0
Регистрация: 16.11.2009
Сообщений: 63
04.12.2013, 23:27  [ТС]
Большое спасибо! Буду пробовать.
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
05.12.2013, 07:13
Цитата Сообщение от PaWeLL Посмотреть сообщение
А если, предположим, в базе будут пустые ячейки у некоторых записях. Разве они не окажутся в результате по критерию is null?
IS NULL накладывается не на поле таблицы, а на параметр. Таким образом, если у вас будет передан не нулевой параметр, то строки, содержащие пустые (NULL) ячейки не выведутся в принципе.
0
0 / 0 / 0
Регистрация: 10.04.2013
Сообщений: 11
06.12.2013, 13:11
Прикрути entity framework/nhibernate и используй linq, либо погугли в сторону dynamic sql
0
1 / 1 / 0
Регистрация: 16.11.2009
Сообщений: 63
11.02.2014, 15:47  [ТС]
Все этот момент мне до конца не понятен. Если все критерии поиска строкового типа, то поиск работает.
Но, если в критериях появляется критерий типа int, то запрос работать перестает, потому как int пустым быть не может и передается нулевое значение.
Что с этим можно сделать?
0
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
11.02.2014, 17:02
SQL
1
OR @category_id <(=,<>) X
0
1 / 1 / 0
Регистрация: 16.11.2009
Сообщений: 63
12.02.2014, 13:56  [ТС]
Цитата Сообщение от Grishaco Посмотреть сообщение
SQL
1
OR @category_id <(=,<>) X
Не могу понять, как использовать эту конструкцию на деле.
0
158 / 187 / 48
Регистрация: 25.11.2013
Сообщений: 978
12.02.2014, 14:00
SQL
1
WHERE CategoryId = @CategoryId OR @CategoryId IS NULL
1
438 / 362 / 100
Регистрация: 29.06.2010
Сообщений: 981
Записей в блоге: 1
12.02.2014, 14:01
Лучший ответ Сообщение было отмечено tezaurismosis как решение

Решение

Цитата Сообщение от PaWeLL Посмотреть сообщение
Не могу понять, как использовать эту конструкцию на деле.
В условии ниже определено, что выборка в случае если @category_id пустая или имеет значение или меньше нуля. Т.е. поставив равно 0, вы получите то что ожидаете.

SQL
1
WHERE   (@category_id IS NULL OR [category_id] = @category_id OR @category_id < 0)
1
1 / 1 / 0
Регистрация: 16.11.2009
Сообщений: 63
17.02.2014, 10:42  [ТС]
Grishaco, ваш вариант вроде бы работает, пока есть только один int. Но если добавить еще один int, то запрос снова перестает работать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
17.02.2014, 10:42
Помогаю со студенческими работами здесь

Ошибка при выполнении SQL запроса "Слишком мало параметров требуется 1"
Доброго времени суток! Столкнулся со следующей проблемой: после перемещения файла Excel с макросом на другой компьютер при выполнении...

Использование параметров для запроса в MYSQL
Добрый день. Подскажите что не правильно делаю... Мануал Mysql читал, делал по нему, но увы с параметрами не получилось... Проблема...

Посоветуйте набор для программирования на sql
Скоро начнутся бд в университете, хочется подготовиться и установит среду для разработки. Я тут почитал, что все по отдельности...

Составление параметров для запроса JSON, ajax
Пытаюсь отправить запрос к vk.com методом ads.getTargetingStats. Все ругается на то что параметр &quot;criteria&quot; не является...

Создание SQL запроса для БД
Имеется 2БД с полями : 1)Платежи (Номер квитанции, Вид платежа, сумма платежа, дата плате- жа, код члена кооператива) 2)Члены...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных через динамический список в справочнике
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru