MSSQL 加密 使用 sys.fn_VarBinToHexStr() hashbytes()

本文介绍了如何在MSSQL中使用`hashbytes()`和`sys.fn_VarBinToHexStr()`函数进行MD5加密。通过创建一个名为`MD5`的用户定义函数,实现了对输入字符串的MD5加密,并提供了加密16位和32位的选项。此外,还创建了一个触发器`trg_EncryptPwd`,在用户表`Users`中插入或更新密码时自动加密。要查询加密后的密码,可以使用相同加密函数进行比较。
摘要由CSDN通过智能技术生成

注意:

hashbytes()返回varbinary类型值; 
sys.fn_VarBinToHexStr()是把varbinary转换成varchar;

 

具体使用方式如下:

 

-- =============================================

-- Description:  实现MD5加密算法,返回对字符串的加密结果串

-- =============================================

CREATE FUNCTION MD5

(

    -- 源字符串

    @src varchar(255),

    -- 加密类型(16/32)

    @type int = 32

)

RETURNS varchar(255)

WITH EXECUTE AS CALLER

AS

BEGIN

    -- 存放md5加密串(ox)

    DECLARE @smd5 var

已以用户 NT SERVICE\SQLSERVERAGENT 的身份执行。 ...息 0) select @b =count(1) from QD_HK.dbo.data0060 a where not exists ( select 1 from data0060(NOLOCK) where sales_order=a.sales_order ) and ( LAST_PUSH_FLAG=9 or sales_order like '_RT%') and whse_ptr=2 [SQLSTATE 01000] (消息 0) 1 [SQLSTATE 01000] (消息 0) DOWNRORDER : ##temp0@STRSQL [SQLSTATE 01000] (消息 0) select RKEY,SFLAG into ##t20230419170801842 from QD_HK.dbo.data0060 a where not exists (select 1 from data0060(NOLOCK) where sales_order=a.sales_order ) and ( LAST_PUSH_FLAG=9 or sales_order like '_RT%') and whse_ptr=2 [SQLSTATE 01000] (消息 0) declare rst2 cursor for select RKEY from ##t20230419170801842 order by SFLAG [SQLSTATE 01000] (消息 0) DOWNORDERA:into ##tmp @strSQL [SQLSTATE 01000] (消息 0) select master.dbo.fn_varbintohexstr(SFLAG) as SFLAG2,* into ##t20230419170802206 from QD_HK.dbo.data0060 where RKEY= ' 536440' [SQLSTATE 01000] (消息 0) update ##t20230419170802206 set analysis_code_3=b.cust_code,endcust_code=b.cust_code,endcust_ptr=b.rkey from ##t20230419170802206 a ,QD_HK.dbo.data0010 b where a.customer_ptr=b.rkey [SQLSTATE 01000] (消息 0) update ##t20230419170802206 set analysis_code_4=b.LOCATION from ##t20230419170802206 a ,QD_HK.dbo.data0012 b where a.CUST_SHIP_ADDR_PTR=b.rkey [SQLSTATE 01000] (消息 0) HK [SQLSTATE 01000] (消息 0) update ##t20230419170802206 set CUSTOMER_PTR= 4212,PART_PRICE=outprice [SQLSTATE 01000] (消息 0) update ##t20230419170802206 set status=6 where status=1 and quote_price=0 [SQLSTATE 01000] (消息 0) update ##t20230419170802206 set CUST_SHIP_ADDR_PTR=(select top 1 RKEY from Data0012 where CUSTOMER_PTR= 4212) [SQLSTATE 01000] (消息 0) so_offer_ptr [SQLSTATE 01000] (消息 0) select @tmpRKEY=so_offer_ptr from ##t20230419170802206 [SQLSTATE 01000] (消息 0) ORDERDOWN60A:集团系统中RKEY [SQLSTATE 01000] (消息 0) 150 [SQLSTATE 01000] (消息 0) select @tmpRKEY2=RKEY from data0009 where RKEY_OLD= 150 AND (isnull( FMCOMPANY,'')='HK' or isnull( FMCOMPANY,'')='') [SQLSTATE 01000] (消息 0) DOWNORDERA:工厂系统中RKEYc [SQLSTATE 01000] (消息 0) 150 [SQLSTATE 01000] (消息 0) DOWNORDERA:: UPDATE_ptrnewvalue@strSQL [SQLSTATE 01000] (消息 0) update ##t20230419170802206 set so_offer_ptr= 150 [SQLSTATE 01000] (消息 0) CURRENCY_PTR [SQLSTATE 01000] (消息 0) select @tmpRKEY=CURRENCY_PTR from ##t20230419170802206 [SQLSTATE 01000] (消息 0) ORDERDOWN60A:集团系统中RKEY [SQLSTATE 01000] (消息 0) 3 [SQLSTATE 01000] (消息 0) select @tmpRKEY2=RKEY from data0001 where RKEY_OLD= 3 AND (isnull( FMCOMPANY,'')='HK' or isnull( FMCOMPANY,'')='') [SQLSTATE 01000] (消息 0) DOWNORDERA:工厂系统中RKEYc [SQLSTATE 01000] (消息 0) 3 [SQLSTATE 01000] (消息 0) DOWNORDERA:: UPDATE_ptrnewvalue@strSQL [SQLSTATE 01000] (消息 0) update ##t20230419170802206 set CURRENCY_PTR= 3 [SQLSTATE 01000] (消息 0) CONF_BY_EMPL_PTR [SQLSTATE 01000] (消息 0) select @tmpRKEY=CONF_BY_EMPL_PTR from ##t20230419170802206 [SQLSTATE 01000] (消息 0) ORDERDOWN60A:集团系统中RKEY [SQLSTATE 01000] (消息 0) SUPPLIER_PTR [SQLSTATE 01000] (消息 0) select @tmpRKEY=SUPPLIER_PTR from ##t20230419170802206 [SQLSTATE 01000] (消息 0) ORDERDOWN60A:集团系统中RKEY [SQLSTATE 01000] (消息 0) CSI_USER_PTR [SQLSTATE 01000] (消息 0) select @tmpRKEY=CSI_USER_PTR from ##t20230419170802206 [SQLSTATE 01000] (消息 0) ORDERDOWN60A:集团系统中RKEY [SQLSTATE 01000] (消息 0) 969 [SQLSTATE 01000] (消息 0) select @tmpRKEY2=rkey from data0073 where RKEY_OLD= 969 AND (isnull( FMCOMPANY,'')='HK' or isnull( FMCOMPANY,'')='') [SQLSTATE 01000] (消息 0) DOWNORDERA:工厂系统中RKEYc [SQLSTATE 01000] (消息 0) 969 [SQLSTATE 01000] (消息 0) DOWNORDERA:: UPDATE_ptrnewvalue@strSQL [SQLSTATE 01000] (消息 0) update ##t20230419170802206 set CSI_USER_PTR = 969 [SQLSTATE 01000] (消息 0) PRINTED_BY_PTR [SQLSTATE 01000] (消息 0) select @tmpRKEY=PRINTED_BY_PTR from ##t20230419170802206 [SQLSTATE 01000] (消息 0) ORDERDOWN60A:集团系统中RKEY [SQLSTATE 01000] (消息 0) WHSE_PTR [SQLSTATE 01000] (消息 0) select @tmpRKEY=WHSE_PTR from... 该步骤失败。
最新发布
04-20
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值