MyBatis 汉字作为查询条件查询不到 MySQL 中的结果

在使用mybitis 查询mysql数据库的时候 用到了汉字作为查询条件,sql语句在navcat里面可以查询的到但是在项目里确不行了

1. 以下是项目中的SQL 文件。

因为where条件中传输进来的参数是汉字,所以在查询的时候,加上 where 子句返回的结果就为空。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.lin.dao.OperatingStatusDao">

    <!--查询指标体系准则层元素,用于打分并计算权重 -->
    <select id="selectIndicator_level" resultType="com.lin.domain.Value">
        select Indicator_level as value from t_yxzt_indexsystem where criterion_level= #{selectName,jdbcType=VARCHAR}
    </select>
</mapper>

2. 控制台输出
在控制台输出,拼音、数字都的可以查到,汉字的查不到。初步判断是字符的编码问题。

3.修改 MySQL 的字符编码形式

隐约记得在安装 MySQL 的时候,没有改变字符编码,选择了默认的latin1,这里应该就是问题的出处

  • 找到 MySQL 的的安装目录
    默认安装路径为:C:\Program Files\MySQL\MySQL Server 5.5,选择 my.ini 文件这里写图片描述

修改其中的两个位置,将下图中用红圈圈出的地方改为 utf8 即可
这里写图片描述

4. 重启 MySQL
用管理员方式启动 cmd 窗口,执行如下语句:

  • 使用命令语句“net stop mysql” 停止 mysql 服务
  • 使用命令语句“net start mysql” 启动 mysql 服务
  • 6
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值