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

Вниз

Как правильнее запрос через ADO или хранимка и sp_executeSql   Найти похожие ветки 

 
svv   (2006-07-20 13:41) [0]

Добрый день!!!

Вот какой вопрос:
есть таблица названий городов, с полем del-признак удалеенности строки.
Почти всегда надо запрашивать данные без удаленных, поэтому подумал что правильнее использовать Хранимую процедуру, НО ИНОГДА НАДО ЗАПРАШИВАТЬ ВСЕ ЗАПИСИ и вот тут возник этот вопрос.
А именно - как сделать правильнее, вот кикие виже варинты (указываю все которое придумал):
1. обычный селект через ADOQuery и если надо дописывать WHERE del=0 или не дописывать этого
2. Две хранимки, Get_goroda и get_gorodaall - но этот вариант не нравиться
3. Хранимка с sp_execsql и по значению параметра менять выполняемый запрос
4. ADOQuery  с sp_execsql

Вот. И что выбрать?

ЗЫ Ожидается много пользователей, так что сохранение плана выполнения не так уж и плохо...

Большое Спасибо!


 
stone ©   (2006-07-20 13:57) [1]


> 2. Две хранимки, Get_goroda и get_gorodaall - но этот вариант
> не нравиться

Достаточно одной
create procedure Get_goroda
@Del bit = null
as
select * from goroda where @Del is null or del=@Del

таким образом сможешь получать не только все записи но и по выбору удаленные/не удаленные


 
Ega23 ©   (2006-07-20 13:59) [2]

CREATE PROCEDURE S_ ......
@ActNam varchar(32)="NONE",
       @Del int=-1,
   ...... Остальные параметры

AS
Declare
  @Result int;

Select @ActNam=RTrim(LTrim(UPPER(@ActNam)));
Set @Result=0;

if ActNam="SEL"
begin
  Select * from ....
  where (@Del=-1 or Del=@Del)
end;

FIN:
Set Nocount OFF;
return(@result);
GO


exec S_.... @ActNam="SEL" - вернёт всё
exec S_.... @ActNam="SEL", @Del=0 - вернёт всё, где del=0
exec S_.... @ActNam="SEL", @Del=1 - вернёт всё, где del=1


 
svv   (2006-07-20 14:23) [3]

2: stone
Спасибо!!!! Что-то я не сообразил...
Что-то такое и надо было!



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

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

Наверх




Память: 0.47 MB
Время: 0.029 c
3-1153332500
DimDim
2006-07-19 22:08
2006.09.24
Запрос с вычислением


15-1157430752
Pazitron_Brain
2006-09-05 08:32
2006.09.24
E-mail - SMS


15-1157055376
Torry
2006-09-01 00:16
2006.09.24
ISDEF 2006 Start


15-1157543985
Карелин Артем
2006-09-06 15:59
2006.09.24
1 зарядка на 4 сотовых разных фирм.


6-1146596297
Evereve
2006-05-02 22:58
2006.09.24
блокировать соединение с Интернетом