UTL_RAW v17
The UTL_RAW
package allows you to manipulate or retrieve the length of raw data types.
Note
An administrator must grant execute privileges to each user or group before they can use this package.
Function/procedure | Function or procedure | Return type | Description |
---|---|---|---|
CAST_TO_RAW(c IN VARCHAR2) | Function | RAW | Converts a VARCHAR2 string to a RAW value. |
CAST_TO_VARCHAR2(r IN RAW) | Function | VARCHAR2 | Converts a RAW value to a VARCHAR2 string. |
CONCAT(r1 IN RAW, r2 IN RAW, r3 IN RAW,…) | Function | RAW | Concatenates multiple RAW values into a single RAW value. |
CONVERT(r IN RAW, to_charset IN VARCHAR2, from_charset IN VARCHAR2) | Function | RAW | Converts encoded data from one encoding to another and returns the result as a RAW value. |
LENGTH(r IN RAW) | Function | NUMBER | Returns the length of a RAW value. |
SUBSTR(r IN RAW, pos IN INTEGER, len IN INTEGER) | Function | RAW | Returns a portion of a RAW value. |
EDB Postgres Advanced Server's implementation of UTL_RAW
is a partial implementation when compared to Oracle's version. Only the functions and procedures listed in the table are supported.
CAST_TO_RAW
The CAST_TO_RAW
function converts a VARCHAR2
string to a RAW
value. The signature is:
The function returns a RAW
value if you pass a non-NULL
value. If you pass a NULL
value, the function returns NULL
.
Parameters
c
The VARCHAR2
value to convert to RAW
.
Example
This example uses the CAST_TO_RAW
function to convert a VARCHAR2
string to a RAW
value:
The result set includes the content of the original string and the converted RAW
value:
CAST_TO_VARCHAR2
The CAST_TO_VARCHAR2
function converts RAW
data to VARCHAR2
data. The signature is:
The function returns a VARCHAR2
value if you pass a non-NULL
value. If you pass a NULL
value, the function returns NULL
.
Parameters
r
The RAW
value to convert to a VARCHAR2
value.
Example
This example uses the CAST_TO_VARCHAR2
function to convert a RAW
value to a VARCHAR2
string:
The result set includes the content of the original string and the converted RAW
value:
CONCAT
The CONCAT
function concatenates multiple RAW
values into a single RAW
value. The signature is:
The function returns a RAW
value. Unlike the Oracle implementation, the EDB Postgres Advanced Server implementation is a variadic function and doesn't place a restriction on the number of values that can be concatenated.
Parameters
r1, r2, r3,…
The RAW
values for CONCAT
to concatenate.
Example
This example uses the CONCAT
function to concatenate multiple RAW
values into a single RAW
value:
The result (the concatenated values) is then converted to VARCHAR2
format by the CAST_TO_VARCHAR2
function.
CONVERT
The CONVERT
function converts a string from one encoding to another encoding and returns the result as a RAW
value. The signature is:
The function returns a RAW
value.
Parameters
r
The RAW
value to convert.
to_charset
The name of the encoding to which r
is converted.
from_charset
The name of the encoding from which r
is converted.
Example
This example uses the UTL_RAW.CAST_TO_RAW
function to convert a VARCHAR2
string (Accounts
) to a raw value. It then converts the value from UTF8
to LATIN7
and then from LATIN7
to UTF8
:
The example returns the VARCHAR2
value, the RAW
value, and the converted values:
LENGTH
The LENGTH
function returns the length of a RAW
value. The signature is:
The function returns a RAW
value.
Parameters
r
The RAW
value for LENGTH
to evaluate.
Example
This example uses the LENGTH
function to return the length of a RAW
value:
This example uses the LENGTH
function to return the length of a RAW
value that includes multi-byte characters:
SUBSTR
The SUBSTR
function returns a substring of a RAW
value. The signature is:
This function returns a RAW
value.
Parameters
r
The RAW
value from which the substring is returned.
pos
The position of the first byte of the returned substring in the RAW
value .
- If
pos
is0
or1
, the substring begins at the first byte of theRAW
value. - If
pos
is greater than one, the substring begins at the first byte specified bypos
. For example, ifpos
is3
, the substring begins at the third byte of the value. - If
pos
is negative, the substring begins atpos
bytes from the end of the source value. For example, ifpos
is-3
, the substring begins at the third byte from the end of the value.
len
The maximum number of bytes to return.
Example
This example uses the SUBSTR
function to select a substring that begins 3
bytes from the start of a RAW
value:
This example uses the SUBSTR
function to select a substring that starts 5 bytes from the end of a RAW
value: