ibatis 模糊查询 mysql_Mybatis使用MySQL模糊查询时输入中文检索不到结果怎么办

项目开发中,在做Mybatis动态查询时,遇到了一个问题:MySQL在进行LIKE模糊查询时,输入英文可以正常检索出结果,但是输入中文后检索得到的结果为空。

由于是使用GET方式请求,所以为了确保中文不乱码,在控制台接收到请求参数后,对中文进行了一次编码。

try {

realName = new String(realName.getBytes("GBK"), "UTF-8");

} catch (UnsupportedEncodingException exception) {

logger.error("realName在进行UTF-8编码时出错," + exception.toString());

}

Mybatis动态SQL映射,具体的SQL如下:

8de932f91fb8c96fc604c1a670f048b7.png

首先使用模糊查询检索英文。启动项目,输入英文“test”,按照英文内容检索得到的结果如下图:

89392ff07bad86863419c0fd2135e245.png

我们可以看到SQL正常执行,使用“test”总共检索出2条结果,数据库中对应字段的内容分别是张三test02和张三test,正常来说,如果我们输入中文“张”也可以查询到这两条数据,下面试试使用模糊查询检索中文。启动项目,输入中文“张”,检索得到结果如下图:

a99cd679a4a20f1c5b7cfffaa951bc69.png

我们可以看到这里检索出的结果是0条记录,并且条件的中文内容没有乱码,和预想中的并不一样。复制同样的SQL语句到SQLyog中执行是可以正常检索出结果的。

在使用SQLServer时并没有出现过这样的问题,这次使用MySQL才出现这种情况,怀疑是在Mybatis配置数据源environment时SQLServer和MySQL配置的内容有差异,仔细对比并上网查阅相关内容后发现,MySQL在进行中文检索时,需要在jdbcURL后增加参数useUnicode=true&characterEncoding=UTF-8来指定编码格式。

e21e0fe78706c25eb30dd525540f7289.png

完整的URL:

jdbc:mysql://127.0.0.1:3306/fanyl_web?useUnicode=true&characterEncoding=UTF-8

在修改了MySQL的jdbcURL后,启动项目,继续输入中文“张”,检索得到结果如下:

c2c1730f44f61c112cc8a515aa1c0166.png

总共检索出3条结果,至此Mybatis使用MySQL进行模糊查询时输入中文检索不到结果的问题就解决了。

另外再附上MySQL的jdbcURL中常见的几个参数说明:

43bb4164ab9fc709a418611f30a84a51.png

以上所述是小编给大家介绍的Mybatis使用MySQL模糊查询时输入中文检索不到结果怎么办,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

时间: 2016-07-05

在IntelliJ IDEA中使用MyBatis进行MySQL模糊查询,通常涉及到动态SQL和MyBatis的SQL映射文件(*.xml)以及Mapper接口的编写。以下是基本步骤: 1. **设置XML映射文件**: - 在MyBatis的`mapper`目录下创建一个新的 XML 文件,比如 `UserMapper.xml`。 - 在XML文件中,定义一个查询语句,例如用于模糊查询用户名称,你可以使用 `<select>` 标签并设置其 `resultType` 属性指定结果数据类型的字段。 ```xml <select id="getUserByNickNameLike" parameterType="map" resultType="com.example.User"> SELECT * FROM user WHERE nickname LIKE #{nickname} %; </select> ``` 这里的 `#{nickname}` 是一个占位符,表示传入的查询参数。 2. **编写Mapper接口**: - 创建对应的 Mapper 接口,如 `UserMapper.java`,导入对应实体类 (`com.example.User`) 和 MyBatis 的注解库。 ```java import com.example.User; import org.apache.ibatis.annotations.Select; public interface UserMapper { @Select("SELECT * FROM user WHERE nickname LIKE #{nickname} %") List<User> getUserByNickNameLike(Map<String, String> params); } ``` 3. **使用服务层调用**: - 在你的业务层(service或controller),注入 `UserMapper`,然后调用模糊查询方法,并传递参数。 ```java @Autowired private UserMapper userMapper; Map<String, String> params = new HashMap<>(); params.put("nickname", "%关键字%"); List<User> users = userMapper.getUserByNickNameLike(params); ``` 4. **传递参数**: - 参数 `params` 中的 "关键字" 将会被替换为实际的查询字符串。例如,如果传入 "abc",会查找到所有名字以 "abc" 开头的用户。 **相关问题--:** 1. 我如何自定义MyBatis的模糊匹配模式? 2. 使用MyBatis的`LIKE`查询是否会影响性能?如何优化? 3. 如果需要同模糊查询多个字段,应该如何修改上述代码?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值