0

我遇到了一些从未实现过的代码(见下文)。

CREATE TABLE encryption_values
(
  NAME   VARCHAR2(6),
  VALUE  NVARCHAR2(100)
);
/

insert into encryption_values
select 'key' name,
rawtohex (
rpad ('52AB32;^$!ER94988OPS3W21@@=WTQ32',32,'X')
) value
from dual
union
select 'iv' name,
rawtohex (
rpad ('TY54ABCX12@÷×+==643QREVDG43AAYMN',32,'X')
) value
from dual;

我想将表定义从 NVARCHAR2(100) 更改为 RAW(256)。我尝试使用 UTL_RAW.cast_to_raw() 但遇到了一些语法错误。有人可以为我提供正确的语法。注意我想保留 RPAD 以确保我正在转换 32 个字符字节。

我正在寻找将数据插入到此表定义中。


CREATE TABLE encryption_values
(
  NAME   VARCHAR2(6),
  VALUE  RAW(256)
);
/

4

1 回答 1

1

您使用了错误的功能,rawtohex. 您必须cast_to_raw从包装中使用您的情况utl_raw

此函数将使用某些数据字节数表示的 VARCHAR2 值转换为具有该数据字节数的 RAW 值。数据本身没有以任何方式修改,但其数据类型被重铸为 RAW 数据类型。

演示

SQL> desc encryption_values
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 NAME                                               VARCHAR2(6)
 VALUE                                              RAW(256)

SQL> insert into encryption_values
  2  select 'key' name,
  3  utl_raw.cast_to_raw (rpad('52AB32;^$!ER94988OPS3W21@@=WTQ32',32,'X')) value
  4  from dual
  5  union
  6  select 'iv' name,
  7  utl_raw.cast_to_raw (rpad('TY54ABCX12@÷×+==643QREVDG43AAYMN',32,'X')) value
  8* from dual
SQL> /

2 rows created.

SQL> select * from encryption_values ;

NAME
------
VALUE
--------------------------------------------------------------------------------
iv
5459353441424358313240EFBFBDEFBFBDEFBFBDEFBFBD2B3D3D3634335152455644473433414159

key
3532414233323B5E2421455239343938384F50533357323140403D5754513332
于 2021-10-06T19:01:09.570 回答