UPDATE ORDERS SET TotalCost = DBMS_CRYPTO.ENCRYPT( UTL_RAW.CAST_TO_RAW(TotalCost), DBMS_CRYPTO.TYPE_AES256, UTL_RAW.CAST_TO_RAW('618272') ) WHERE TotalCost IS NOT NULL; UPDATE PRODUCT SET Price = DBMS_CRYPTO.ENCRYPT( UTL_RAW.CAST_TO_RAW(Price), DBMS_CRYPTO.TYPE_AES256, UTL_RAW.CAST_TO_RAW('618272') ) WHERE Price IS NOT NULL; UPDATE ORDERS_DETAILS SET Price = DBMS_CRYPTO.ENCRYPT( UTL_RAW.CAST_TO_RAW(Price), DBMS_CRYPTO.TYPE_AES256, UTL_RAW.CAST_TO_RAW('618272') ) WHERE Price IS NOT NULL; UPDATE TRANSACTION SET TotalAmount = DBMS_CRYPTO.ENCRYPT( UTL_RAW.CAST_TO_RAW(TotalAmount), DBMS_CRYPTO.TYPE_AES256, UTL_RAW.CAST_TO_RAW('618272') ) WHERE TotalAmount IS NOT NULL; UPDATE TRANSACTION_DETAILS SET Price = DBMS_CRYPTO.ENCRYPT( UTL_RAW.CAST_TO_RAW(Price), DBMS_CRYPTO.TYPE_AES256, UTL_RAW.CAST_TO_RAW('618272') ) WHERE Price IS NOT NULL; UPDATE SALARY SET SalaryAmount = DBMS_CRYPTO.ENCRYPT( UTL_RAW.CAST_TO_RAW(SalaryAmount), DBMS_CRYPTO.TYPE_AES256, UTL_RAW.CAST_TO_RAW('618272') ) WHERE SalaryAmount IS NOT NULL;
时间: 2023-08-16 07:05:06 浏览: 65
这是一个 SQL 查询语句,它使用 Oracle 数据库的 DBMS_CRYPTO 函数将某些列的数据进行加密。具体来说,它将订单表中的 TotalCost 列、产品表中的 Price 列、订单详情表中的 Price 列、交易表中的 TotalAmount 列、交易详情表中的 Price 列以及薪资表中的 SalaryAmount 列进行加密。
加密使用的是 AES256 算法,并且密钥为 '618272'。这意味着只有知道密钥的人才能够解密这些列的数据。这样做可以保护这些敏感数据,防止它们被未经授权的人员访问。
相关问题
改正:ALTER TABLE ORDERS MODIFY TotalCost NUMBER(35,2);DECLARE i_key RAW(32); BEGIN i_key :=UTL_RAW.cast_to_raw('618272'); UPDATE ORDERS SET TotalCost = DBMS_CRYPTO.ENCRYPT( src=>UTL_RAW.CAST_TO_RAW(TotalCost), typ=>DBMS_CRYPTO.AES_CBC_PKCS5, key=>i_key, iv=>NULL ) WHERE TotalCost IS NOT NULL; END; /
修改:ALTER TABLE ORDERS MODIFY TotalCost NUMBER(35,2);
DECLARE
i_key RAW(32);
BEGIN
i_key := UTL_RAW.cast_to_raw('618272');
UPDATE ORDERS
SET TotalCost = DBMS_CRYPTO.ENCRYPT(
src => UTL_RAW.CAST_TO_RAW(TO_CHAR(TotalCost)),
typ => DBMS_CRYPTO.AES_CBC_PKCS5,
key => i_key,
iv => NULL
)
WHERE TotalCost IS NOT NULL;
END; /
这个修改过的代码将 TotalCost 列中的值进行了加密,并将其更新回数据库。在这里,我们使用 AES_CBC_PKCS5 加密算法对 TotalCost 进行加密,使用的密钥是 '618272'。注意,我们需要通过 TO_CHAR 函数将 TotalCost 转换为字符串类型,以便进行加密。
改正:ALTER TABLE ORDERS MODIFY TotalCost NUMBER(35,2); DECLARE i_key RAW(32); BEGIN i_key :=UTL_RAW.cast_to_raw('618272'); UPDATE ORDERS SET TotalCost = DBMS_CRYPTO.ENCRYPT( src=>UTL_RAW.CAST_TO_RAW(TO_CHAR(TotalCost)), typ=>DBMS_CRYPTO.AES_CBC_PKCS5, key=>i_key, iv=>NULL ) WHERE TotalCost IS NOT NULL; END; /
这段代码的作用是修改 ORDERS 表的 TotalCost 字段的数据类型为 NUMBER(35,2),并对 TotalCost 字段中非空的数据进行 AES CBC PKCS5 加密,并使用给定的 key 值进行加密。其中,key 的值为 618272。
下面是修改后的代码:
```
ALTER TABLE ORDERS MODIFY TotalCost NUMBER(35,2);
DECLARE
i_key RAW(32);
BEGIN
i_key := UTL_RAW.cast_to_raw('618272');
UPDATE ORDERS
SET TotalCost = DBMS_CRYPTO.ENCRYPT(
src => UTL_RAW.CAST_TO_RAW(TO_CHAR(TotalCost)),
typ => DBMS_CRYPTO.AES_CBC_PKCS5,
key => i_key,
iv => NULL
)
WHERE TotalCost IS NOT NULL;
END;
/
```
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![xlsx](https://img-home.csdnimg.cn/images/20210720083732.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)