在使用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 服务