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:整数,指定子串的长度(要返回的字符数或字节数)

posted @   每天进步多一点  阅读(386)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 2 本地部署DeepSeek模型构建本地知识库+联网搜索详细步骤
点击右上角即可分享
微信分享提示