这里是在mysql中自定义了一个函数,但返回的字段定义为varchar类型,数据中包含中文,所以报java.sql.SQLException: Incorrect string value: '\xE6\x9D\x8E\xE5\x87\xA4'异常。
经过度娘帮助,综合了两个方法得以解决,而不用修改数据库编码(还不一定有用)。方法记录如下:
1、将自定义函数中的变量类型,从varchar改为nvarchar
2、使用加密解密的方式把数据返回
RETURN AES_ENCRYPT(返回值,加密的Key);
END
执行查询
或在mapp.xml中修改
select AES_DECRYPT(自定义函数,加密的key)
至此问题解决
本文介绍了一种在MySQL中处理自定义函数返回中文字符时出现的java.sql.SQLException异常的方法,通过将变量类型从varchar改为nvarchar及使用AES加密解密方式返回数据,有效解决了中文字符编码问题。
2160

被折叠的 条评论
为什么被折叠?



