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

Вниз

Oracle и побитовые операции   Найти похожие ветки 

 
Michail Dalakov ©   (2004-02-28 12:12) [0]

Как известно в Oracle есть пакет для выполнения побитовых операций с типом данных RAW. Как проделать то же самое с типом Number не прибегая к преобразованию типов


 
Reindeer Moss Eater ©   (2004-02-28 12:30) [1]

BITAND
Для целых положительных аргументов


 
Michail Dalakov ©   (2004-02-28 12:40) [2]

Спасибо, странно что эта ф-ия недокументирована


 
Michail Dalakov ©   (2004-02-28 14:05) [3]

А есть ли ф-ия побитового ОR? И как она выглядит в этом случае?


 
Reindeer Moss Eater ©   (2004-02-28 14:29) [4]

Нету.
Но ее можно эмулировать.

исходное значение
Result:=2; -- $0010

Поднять третий бит справа
Result := BITAND(result,11) + 4

Поднять четвертый бит справа
Result := BITAND(result,7) + 8


 
Michail Dalakov ©   (2004-02-28 15:19) [5]

Ну да, но если надо установить несколько бит, то это будет столько же операций +2^n, правда в приведенном примере я не понял почему не просто

Поднять третий бит справа
Result := result + 4

Поднять четвертый бит справа
Result := result + 8


 
Reindeer Moss Eater ©   (2004-02-28 15:20) [6]

А если он уже поднят?


 
Reindeer Moss Eater ©   (2004-02-28 15:24) [7]

то это будет столько же операций +2^n,

Поднять третий и четвертый бит справа

result := BITAND(result,3) + 12

Одна операция


 
Michail Dalakov ©   (2004-02-28 15:42) [8]

To [6] Сoгласен
To [7] Да, но в этом случае надо держать массив, где количество
элементов = 2*2^n, n-количество бит, и делать
result := BITAND(result,A[i]) + B[i]


 
Reindeer Moss Eater ©   (2004-02-28 15:44) [9]

LarryAllison@oracle.com


 
Reindeer Moss Eater ©   (2004-02-28 15:49) [10]

Кроме того никто не запрещает реализовать OR на встроенной яве


 
Michail Dalakov ©   (2004-02-28 16:03) [11]

Согласен,
Спасибо, особенно за Reindeer Moss Eater ©   (28.02.04 12:30) [1]



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

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

Наверх




Память: 0.49 MB
Время: 0.027 c
6-1074410616
SergP
2004-01-18 10:23
2004.03.28
Как прочитать текст странички из окна эксплорера?


7-1072953385
DelphiN!
2004-01-01 13:36
2004.03.28
Скрыть процесс от TaskMenagera в NT-ях


9-1062317384
booblik
2003-08-31 12:09
2004.03.28
фатал еррор


14-1078092484
Piter
2004-03-01 01:08
2004.03.28
Новый клиент для форума


3-1077188241
Alexei Sviridov
2004-02-19 13:57
2004.03.28
SQL Scripts