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

Вниз

Вопрос по написанию хранимых процедур   Найти похожие ветки 

 
AndrewK ©   (2002-04-16 16:47) [0]

Уважаемые мастера, подскажите как можно реализовать с помощью хранимой процедуры следующую задачку. Есть некоторая выборка из группы таблиц. Есть параметры отображения на эту выборку, например, отфильтровать записи, показать не все поля и т.д. Клиентское приложение работает с хранимой процедурой, которой в качестве парметров передаются эти данные. В зависимости от этих данных надо поменять запрос к базе в процедуре.
Сейчас остановился на том, что для каждой возможной вариации пишу свой запрос а в процедуре развожу их операторами if ... else. Процедура, прямо скажем, глаз уже не радует. Можно ли как-нибудь сделать так, чтобы в зависимости от параметров можно было конструировать запрос один раз? Например что-то вроде такой конструкции (вопрос скорее по синтаксису написания хранимых процедур):

create procedure MyProc @ID int


select
*
from
Tabl

if (@ID = 1) begin
where
....

end

Процедура должна вернуть выборку из всех элементов если @ID<>1, и отфильтровать записи если @ID=1.

Возможно ли такое?


 
DPetrovich ©   (2002-04-16 17:04) [1]

Можно, например, написать так
select * from Tabl where ((@ID<>1) or (@ID=1 and ....))


 
roottim   (2002-04-16 17:10) [2]

yнепонятна формулировка но.. мб
if @id != 1 then
select * from ...
else
select * from .. where

2DPetrovich © (16.04.02 17:04)
@id это параметр а не поле, а если и поле то будет НД состоять из ид=1 и +те картежи которые подойдут по 2-му усл!



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

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

Наверх




Память: 0.47 MB
Время: 0.016 c
1-26152
SP
2002-04-24 14:05
2002.05.09
ListView в виде дерева


6-26209
Sergo
2002-02-26 17:46
2002.05.09
ПРИВЕТ ВСЕМ МАСТЕРАМ...И ВОТ ВОПРОСИК ТАКОЙ ВСПЛЫЛ!!!


3-26000
DRIVER
2002-04-04 17:25
2002.05.09
Где вы мастера!!!!!!!???????


1-26123
Andrey KSO
2002-04-24 17:19
2002.05.09
QuickRep


4-26287
ted
2002-03-06 13:33
2002.05.09
Как получить IP адрес???