SQL Server 內置函數實現MD5加密

一、MD5加密

    HASHBYTES ('加密方式', '待加密的值')

    加密方式= MD2 | MD4 | MD5 | SHA | SHA1

    返回值類型:varbinary(maximum 8000 bytes)

   

二、MD5加密示例

select HASHBYTES('MD5','123456') 

      

     HASHBYTES生成的結果爲:0xE10ADC3949BA59ABBE56E057F20F883E

  注意:一般工具生成的都是沒有0x和是小寫的,16進制的數值,去掉“0x”轉換爲小寫值就完全與MD5值吻合了。

  在此需要用另一個函數(sys.fn_sqlvarbasetostr)把varbinary的值轉換爲varchar類型的

select sys.fn_sqlvarbasetostr(HASHBYTES('MD5','123456')) 

      

   結果:0xe10adc3949ba59abbe56e057f20f883e 截取去掉0x

select substring(sys.fn_sqlvarbasetostr(HASHBYTES('MD5','123456')),3,32

      

   結果就是完整的MD5值:e10adc3949ba59abbe56e057f20f883e

 三、SQL截取字符串substring

   substring 返回字符、binary、text 或 image 表達式的一部分。

   基本語法:SUBSTRING ( expression , start , length )

   expression:字符串、二進制字符串、text、image、列或包含列的表達式

   start:整數,指定子串的開始位置

   注:SQL中"1"表示字符串中的第一個字符,而.NET中"0"表示第一個字符

   length:整數,指定子串的長度(要返回的字符數或字節數)

優秀是一種習慣,歡迎大家關注學習 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章