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

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

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

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




<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 文件MyBatis 汉字作为查询条件查询不到 MySQL 中的结果_第1张图片

修改其中的两个位置,将下图中用红圈圈出的地方改为 utf8 即可
MyBatis 汉字作为查询条件查询不到 MySQL 中的结果_第2张图片

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

  • 使用命令语句“net stop mysql” 停止 mysql 服务
  • 使用命令语句“net start mysql” 启动 mysql 服务

你可能感兴趣的:(MyBatis,SQL)