Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.07.08;
Скачать: CL | DM;

Вниз

Передача параметров в запрос   Найти похожие ветки 

 
alsn   (2002-06-14 13:25) [0]

Здравствуйте. На MSSQL есть таблица Table1 вида
ID, Field1, Field2, ..., Field10. Пусть для простоты все поля будут int.
Создаем процедуру:
create procedure test @param1 int, @param2 int, ..., @param10 int
as begin
Select * From Table1
Where
?????????
end

Параметры @param1 int, @param2 int, ..., @param10 - это
условия, налагаемые на поля Field1, Field2, ..., Field10.
которым должны быть равны значения соответсвующих полей.
Но, условие FieldX = @paramX должно налагаться только если @paramX is Not Null.
Что должно быть записано в предложнении Where
или как это все сделать по другому?
Заранее спасибо.


 
TSV ©   (2002-06-14 13:47) [1]

SELECT ...
FROM Table1
WHERE
(@Param1 is null or Field1 = @Param1)
and (@Param2 is null or Field2 = @Param2)
...

Удачи.


 
MishGan`   (2002-06-14 13:51) [2]

А нельзя так (FieldX = @paramX) OR (@paramX IS NULL)?
Или если все так плохо - используй dynamic sql (EXEC или SP_EXECUTESQL) - ты сможешь формировать условие запроса в процессе выполнения хр. процедуры.


 
Автор вопроса   (2002-06-14 14:19) [3]

2 MishGan:
Если использовать dynamic sql, юзерам придется давать права на чтение этих таблиц, чего делать нельзя.



Страницы: 1 вся ветка

Текущий архив: 2002.07.08;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.008 c
4-23836
Hel
2002-05-07 13:14
2002.07.08
Функция CreateProcess


14-23756
ATLANTIDO
2002-06-06 23:19
2002.07.08
sorry...


1-23626
BKV
2002-06-25 10:45
2002.07.08
Компонент в design-time


3-23486
Turalyon
2002-06-14 14:35
2002.07.08
Помогите сваять SQL запрос


3-23464
AndrewK
2002-06-14 15:57
2002.07.08
Как составить запрос. Неужели это невозможно.