Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2007.10.07;
Скачать: [xml.tar.bz2];

Вниз

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

 
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;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.043 c
1-1185116122
Al_delta
2007-07-22 18:55
2007.10.07
TreeView: неправильно создаются дочерние узлы. Помогите!


15-1189256604
Галинка
2007-09-08 17:03
2007.10.07
Переполнение буфера/кучи


15-1189009721
fisher
2007-09-05 20:28
2007.10.07
cos(x) в полярной системе


4-1175766573
Степан Журавлев
2007-04-05 13:49
2007.10.07
GetParent


2-1187583615
apic
2007-08-20 08:20
2007.10.07
scroll





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский