mysql自定义函数读取中文返回异常java.sql.SQLException: Incorrect string value: '\xE6\x9D\x8E\xE5\x87\xA4'

这里是在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)

至此问题解决

你可能感兴趣的:(通讯开发)