Главная страница
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.013 c
14-26231
Morfey
2002-03-30 18:19
2002.05.09
Гадкий модем


7-26282
andey
2002-02-12 18:56
2002.05.09
Буфер обмена


1-26099
Tonie
2002-04-25 12:34
2002.05.09
AppServer shut down: Проблема при подключенных клиентах ...


3-26041
Тим
2002-04-16 21:24
2002.05.09
Печать в два столбца в Quick Report


3-25999
Oleg Y.
2002-04-15 13:46
2002.05.09
Формат ввода числа в гриде