问题背景
今天在更新数据库某一个值属性的时候,执行更新语句报错提示 -6111: 字符串转换出错,但是自己检查了sql语句,只是一个简单的sql,并没有需要字符串转换的地方,感觉很奇怪
问题分析
根据报错信息来分析,对于达梦数据库错误 -6111 通常表示在数据库操作中,尝试将一个字符串转换为另一种数据类型时失败了。这可能是因为字符串的格式与目标数据类型不兼容,例如,尝试将字符串转换为数值类型,但字符串中包含非数值字符。最终归结到当前语句的问题还是说发生了字符串转换错误。于是我再一次仔细的查看了当前sql语句
UPDATE alm.sys_coa_detail set description='描述当前字段的属性' where id=49;
认真排查了当前sql涉及到的两个字段 description 和 id 最终发现原来 id 竟然也是一个字符串类型
问题总结
到这里,问题分析结束之后就知道问题怎么解决了,就是将sql的条件语句 id 值 换成字符串类型的数字就可以了。那么为什么会出现这么一条简单的更新语句报错的情况呢?其实在发生问题的时候,确实是比较懵的,不管对于新手开发者或者是老手开发者来说,这么简单的更新语句能报错,着实有点奇怪。那么现在找到问题原因之后再来回看为什么会发生这样的错误,一个原因就是表结构id 字段设计成 varchar 类型,这个确实有点反常规。另外一个就是不要太相信以往关于数据库字段的经验,而应该以实际表机构为准,不能想当然的认为 id 就一定是 Long 数值型,总的来说,就是需要认真细致就好了。