A situation has arisen where I need to perform a base 36 to base 10 conversion, in the context of a SQL statement. There doesn\'t appear to be anything built into Oracle 9
select sum(position_value) from
(
select power(36,position-1) * case when digit between '0' and '9'
then to_number(digit)
else 10 + ascii(digit) - ascii('A')
end
as position_value
from (
select substr(input_string,length(input_string)+1-level,1) digit,
level position
from (select '01Z' input_string from dual)
connect by level <= length(input_string)
)
)