Oracle: comment convertir hex en décimal dans Oracle SQL?
comment convertir hexadécimal en décimal (et revenir en arrière) en utilisant Oracle SQL?
19
demandé sur
Matthew Farwell
2009-08-04 15:49:40
4 réponses
pour convertir de hexadécimal en décimal:
select to_number('AA', 'xx') from dual;
pour convertir De décimal en hexadécimal:
select to_char(111, 'xxxx') from dual;
34
répondu
Petros
2012-01-26 06:40:22
SELECT TO_NUMBER('DEADBEEF', 'XXXXXXXX')
FROM dual
---
3735928559
SELECT TO_CHAR(3735928559, 'XXXXXXXX')
FROM dual
---
DEADBEEF
11
répondu
Quassnoi
2009-08-04 11:54:58
à partir de Oracle8i, le TO_CHAR et Les fonctions TO_NUMBER peuvent gérer les conversions à partir de la base 10 (décimal) à base 16 (hexadécimal) et retour:
SQL> select to_char(123,'XX') to_hex,
2 to_number('7B','XX') from_hex
3 from dual
4 /
TO_ FROM_HEX
------ -----------------
7B 123
5
répondu
devio
2009-08-04 11:56:07
FTA: Oracle à la décimale:
CREATE OR REPLACE FUNCTION hex2dec (hexnum IN CHAR) RETURN NUMBER IS
i NUMBER;
digits NUMBER;
result NUMBER := 0;
current_digit CHAR(1);
current_digit_dec NUMBER;
BEGIN
digits := LENGTH(hexnum);
FOR i IN 1..digits LOOP
current_digit := SUBSTR(hexnum, i, 1);
IF current_digit IN ('A','B','C','D','E','F') THEN
current_digit_dec := ASCII(current_digit) - ASCII('A') + 10;
ELSE
current_digit_dec := TO_NUMBER(current_digit);
END IF;
result := (result * 16) + current_digit_dec;
END LOOP;
RETURN result;
END hex2dec;
/
show errors
CREATE OR REPLACE FUNCTION num2hex (N IN NUMBER) RETURN VARCHAR2 IS
H VARCHAR2(64) :='';
N2 INTEGER := N;
BEGIN
LOOP
SELECT RAWTOHEX(CHR(N2))||H
INTO H
FROM dual;
N2 := TRUNC(N2 / 256);
EXIT WHEN N2=0;
END LOOP;
RETURN H;
END num2hex;
/
show errors
3
répondu
dassouki
2009-08-04 11:54:20