Главная страница
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.011 c
3-23437
Tutov Roman
2002-06-13 16:37
2002.07.08
Где найти толковый справочник по SQL языку ?


1-23670
Dj Karies
2002-06-26 12:08
2002.07.08
Потоки(Threads) в DLL


8-23690
Spirit
2002-02-28 09:14
2002.07.08
Как сделать пазл из картинки?


1-23547
Programmer1
2002-06-26 11:24
2002.07.08
Управление word ом из приложения


3-23461
Ptr
2002-06-14 15:16
2002.07.08
IBQuery