不同数据库SQL语句中MD5的写法

最近在使用KingFusion开发MES系统,其中有些通用的功能可以参考以往的项目代码。

在开发调试用户密码重置功能时,遇到一个报错。

于是将报错的SQL语句丢给豆老师,帮忙解析。

01 问题

帮忙解析一下下面的SQL语句,看是否存在错误:

sql 复制代码
UPDATE "AA_Basic_User_Role"

SET "c_Password"=CONVERT(VARCHAR(32), HASHBYTES('MD5', 'Admin@123'), 2)

WHERE "c_StaffID"='P000002' AND "c_StaffName"='雷布斯'

于是豆老师给出了:

主句解析+错误排查+可直接运行的修正版

但由于给出的答案不够精准,于是补充提问:

补充:上面的语句是PG库的SQL语句

很快,豆老师给出了更加精准的回复:

02 先告诉你结论

你这条 SQL 在 PG 里完全不能运行,全是错误!

因为你写的是 SQL Server 语法,PG 不支持。

03 逐句解析错误(PG 环境下)

sql

sql 复制代码
UPDATE "AA_Basic_User_Job"

SET "c_Password"=CONVERT(VARCHAR(32), HASHBYTES('MD5', 'Admin@123'), 2)

WHERE "c_StaffID"='P000002' AND "c_StaffName"='雷布斯'

❶ CONVERT () 函数 → PG 没有这个函数

PG 不支持 CONVERT,这是 SQL Server 专属。

❷ HASHBYTES () 函数 → PG 也没有

HASHBYTES 是 SQL Server 用来做 MD5 的,PG 用 md5()。

❸ VARCHAR (32) 这种写法 PG 不报错,但没必要

❹ 双引号没问题(PG 支持双引号包裹表 / 字段名)

04 PG 中 正确的 MD5 更新语句

直接复制这条就能运行:

sql

sql 复制代码
UPDATE "AA_Basic_User_Role"

SET "c_Password" = md5('Admin@123')

WHERE "c_StaffID" = 'P000002' AND "c_StaffName" = '雷布斯';

效果完全一样:

把密码变成 32 位小写 MD5 字符串。

05 简单对比你就懂了

数据库 MD5 写法
SQL Server HASHBYTES ('MD5', ' 明文 ')
MySQL MD5 (' 明文 ')
PostgreSQL md5 (' 明文 ')

你之前的写法是 SQL Server 专用,放到 PG 里肯定报错。

06 最终正确语句(PG 100% 可用)

sql

sql 复制代码
UPDATE "AA_Basic_User_Role"

SET "c_Password" = md5('Admin@123')

WHERE "c_StaffID" = 'P000002';

(c_StaffID 一般唯一,c_StaffName 可删)

07 总结

原语句错误

用了 SQL Server 专属函数 CONVERT、HASHBYTES

PG 正确 MD5 函数:md5('明文')

直接用我给的最终语句即可执行成功

你在工作过程中有哪些使用AI的场景?效果如何?

欢迎在评论区留言讨论。

相关推荐
ClouGence1 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将3 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils1 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波1 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
zzzzzz3103 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
倔强的石头_5 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横5 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
冬奇Lab6 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence6 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle