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

Вниз

исключение параметров из запроса не меняя тело   Найти похожие ветки 

 
nick_van_rijn ©   (2007-06-01 16:14) [0]

Господа подскажите.
запрс вида
select t1.*,t2.* from t1,t2 where (t1.код=t2.код) and(t1.дата between [:D] and [:D1]) and (t1.Данные like[:N])
Каким образом передавать параметры что бы не меняя тела запроса можно было  выбрать
1. (t1.Данные=[:N]) на все даты
2 с 1 мая по 30 независимо от (t1.Данные=[:N])
Если со вторым понятно -передать "*" как строку, то с датами не все понятно.


 
sniknik ©   (2007-06-01 16:27) [1]

select * from t1 INNER JOIN t2 ON t1.[код]=t2.[код]
where (t1.[дата] between :D and :D1 OR :D2 IS Null) AND (:N1 IS Null OR t1.[Данные] like :N)

> Если со вторым понятно -передать "*" как строку
сравнение на null будет быстрее чем строковое сравнение с "*" (кстати нужно не * а %... или все переделывать раз у тебя BDE)


 
Sergey13 ©   (2007-06-01 16:28) [2]

> [0] nick_van_rijn ©   (01.06.07 16:14)

select t1.*,t2.* from t1,t2 where (t1.код=t2.код)
and((:need_date=1 and t1.дата between [:D] and [:D1]) or :need_date=2)
and ((:need_data=1 and t1.Данные like[:N]) or :need_data=2)


Управляя параметрами :need_date и :need_datа можно достичь желаемого
Если движок не позволяет использовать пераметр дважды, немного модифицируй запрос.


 
nick_van_rijn ©   (2007-06-01 16:34) [3]

>>sniknik © а никто не говорил что bde.


 
nick_van_rijn ©   (2007-06-01 16:38) [4]

конечно два дополнительных параметра это вариант.... но...


 
sniknik ©   (2007-06-01 17:22) [5]

>а никто не говорил что bde.
обдумай фразу тщательнее... там выбор, или/или.

и кстати очень зря, что не говорил.

> конечно два дополнительных параметра это вариант.... но...
ничего не поделаешь. если был не аксесс, а mssql(др.) можно было бы обойтись имеющимися, в нем возможны пакеты команд и переменные в запросах (один раз присваиваеш в нескольких местах используешь).



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

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

Наверх




Память: 0.48 MB
Время: 0.021 c
1-1185171606
DevilDevil
2007-07-23 10:20
2007.10.07
Изменить VMT


4-1175752393
аыпвапы
2007-04-05 09:53
2007.10.07
Alt+Tab как запретить в ХР?


15-1189108877
max_
2007-09-07 00:01
2007.10.07
info


15-1187816153
Real
2007-08-23 00:55
2007.10.07
Видеозахват: глюки на экспорте


15-1189390927
Slider007
2007-09-10 06:22
2007.10.07
С днем рождения ! 10 сентября 2007 понедельник