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

Вниз

Бинарная логика в Firebird   Найти похожие ветки 

 
-SeM-   (2004-03-31 11:01) [0]

В таблице базы Firebird есть поле INTEGER, выполняющее роль битового массива. Каким должно быть условие запроса, чтобы ,например, выбрать все записи с включенным 5 битом этого поля?


 
Johnmen ©   (2004-03-31 11:05) [1]

Использовать UDF. Напр. в RFUNC есть функции битовых операций.


 
-SeM-   (2004-03-31 11:17) [2]

UDF не хотелось бы...
А других вариантов нет?


 
Johnmen ©   (2004-03-31 12:03) [3]

Напр. так
... WHERE
     CAST(MyIntField/16.0-0.5 AS INTEGER)/2.0 -
     CAST((CAST(MyIntField/16.0-0.5 as integer)-0.5)/2.0 AS INTEGER) > 0

если в твоей нумерации 5-ый бит это 16  
:)


 
-SeM-   (2004-03-31 12:51) [4]

Сенкс!
Длинно, но работает :)


 
Digitman ©   (2004-03-31 13:05) [5]


> UDF не хотелось бы


а почему ? идеальный же вариант ..
а CAST"ы подобного рода, как ни крути, на больших НД будут давать ощутимую потерю производительности запросов


 
-SeM-   (2004-04-01 10:45) [6]

Не, я ничего не имею против UDF, просто в данном случае лучше запросом.
Тем более что данных не много :)

Спасибо.
Вопрос снят.


 
Desdechado ©   (2004-04-01 13:48) [7]

так UDF в запросе можно использовать
тем паче в стандартной поставке ib_udf.dll идет с битовыми функциями



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

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

Наверх




Память: 0.47 MB
Время: 0.024 c
1-1081348910
Relaxxx
2004-04-07 18:41
2004.04.25
Забил!!! Напомните пожалуйста как узанать есть ли в слове напри..


8-1074412961
Intell
2004-01-18 11:02
2004.04.25
Как создать эффект шума на форме?


3-1080652383
Ivan
2004-03-30 17:13
2004.04.25
Сумма по QRExpr


1-1081398844
Viktor
2004-04-08 08:34
2004.04.25
Запустить InternetExplorer?


3-1080405086
HeoGtan
2004-03-27 19:31
2004.04.25
Вопрос по D7+ADO+MS.ACCESS97...