oracle 對字段進行 MD5 加密處理函數(shù)

工作需要使用sql對某個字段進行加密處理,創(chuàng)建MD5處理函數(shù)如下:

CREATE OR REPLACE FUNCTION MD5(passwd IN VARCHAR2)RETURN VARCHAR2

IS

????retval varchar2(32);

BEGIN

????retval := utl_raw.cast_to_raw(DBMS_OBFUSCATION_TOOLKIT.MD5(INPUT_STRING => passwd)) ;

????RETURN retval;

END;

使用示例:

select md5(123) from dual

select md5(123) from dual

但是跑數(shù)中途遇到如下報錯:

ORA-28231

檢查發(fā)現(xiàn),當md5函數(shù)輸入?yún)?shù)為空時,導致報錯,修改函數(shù)如下,解決:

CREATE OR REPLACE FUNCTION MD5(passwd IN VARCHAR2)RETURN VARCHAR2

IS

????retval varchar2(32);

BEGIN

????retval := (case when passwd is null then null else utl_raw.cast_to_raw(DBMS_OBFUSCATION_TOOLKIT.MD5(INPUT_STRING => passwd)) end);

????RETURN retval;

END;

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容