在SQL Server 2005下自帶的函數HashBytes() ,此函數是微軟在SQL Server 2005中提供的,可以用來計算一個字符串的MD5和SHA1值,使用方法如下: --獲取123456的MD5加密串 select hashbytes('MD5', '123456') ; --獲取123456的SHA1加密串 select hashbytes('SHA1', '123456') ; 有了這個函數可以在SQL Server中爲字符串進行加密,但是HashBytes() 函數的返回結果是VarBinary類型(以 0x 開頭 16 進制形式的二進制數據)。通常情況下,我們需要的都是字符串型的數據,很多人首先想到的可能就是用CAST或Convert函數將VarBinary轉換爲VarChar,但這樣轉換後的結果會是亂碼,正確轉換VarBinary可變長度二進制型數據到16進制字符串應該使用系統內置函數sys.fn_VarBinToHexStr()或sys.fn_SqlVarBaseToStr(只在SQL Server2005下有),如下所示: select sys.fn_VarBinToHexStr(hashbytes('MD5', '123456')) 然後就可以截取需要的部分: set right(sys.fn_VarBinToHexStr(hashbytes('MD5','123456')),32) 爲MD5加密串。
select UPPER(right(sys.fn_VarBinToHexStr(hashbytes('SHA1','123456')),40))
轉全大寫