Mybatis学习中遇到的错误java.sql.SQLException: Illegal mix of collations (latin1_swedish_ci,IMPLICIT) and (ut

在Mybatis学习存储过程调用的时候,老是出现【java.sql.SQLException: Illegal mix of collations (latin1_swedish_ci,IMPLICIT) and (utf8_general_ci,COERCIBLE) for operation '='】这个错,百度了下意思是返回的结果有两种字符集。一般这种情况在排除编程语言中单独设置的字符集错误后,首先想到的就是数据库中的数据表设置的字符集类型和编程语言中所要得到的结果类型不一致导致的。下面介绍具体的解决办法:

1   输入sql语句:首先看看表结构的类型(一般设置为UTF-8),支持中文类型的:

<span style="font-size:18px;">SHOW VARIABLES LIKE 'character_set_%';</span>

查看下字段类型:

<span style="font-size:18px;">SHOW VARIABLES LIKE 'collation_%';</span>


看到这两处的类型有不是UTF-8的地方了吗?全部都要改成UTF-8类型的:

set character_set_database =utf8;
set character_set_results =utf8;
set character_set_server =utf8;
set character_set_system =utf8;

SET collation_server = utf8_general_ci
SET collation_database = utf8_general_ci

按道理这样就能成功了,但是有几个地方也要注意一下:

 2  数据库中数据表:

3 数据库:


4 这些设置就应该差不多了,而我在设置这些的时候还是报错,原因就是在创建存储过程的时候加入中文字符了。


参考博客:【http://blog.csdn.net/wujingwen1111/article/details/12652819】




这个错误消息是一个SQL异常,指出了一个字符串索引超出范围的问题。具体来说,错误消息的`String index out of range: 168`表示字符串的索引超出了其长度范围。这可能是由于在处理字符串时尝试访问超出字符串长度的索引导致的。这个问题通常出现在处理字符串的操作,例如截取、访问字符等。要解决这个问题,你可以检查代码与字符串操作相关的部分,确保没有超出字符串长度的索引访问。如果你能提供更多的上下文或相关代码,我可以给出更具体的建议。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [mybatis批量插入报下标越界异常:java.sql.SQLException: java.lang.StringIndexOutOfBoundsException](https://blog.csdn.net/admin_Object/article/details/124098182)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [MySQL存储表情时报错:java.sql.SQLException: Incorrect string value:‘\xF0\x9F\x92\xA9\x0D\x0A…’的...](https://download.csdn.net/download/weixin_38685876/13703258)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Cause: java.lang.StringIndexOutOfBoundsException: String index out of range: 0...](https://blog.csdn.net/weixin_34288121/article/details/92397888)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值