一、问题描述
背景:代码迁移,ssm框架在插入数据到mysql数据库时,中文乱码。代码中的编码配置没有问题,因为该项目代码以前使用过,没有问题。现在换了数据库,数据库配置也做了修改,统一使用utf8,但还是乱码,数据库配置存在不知明的原因,但是有别的解决方法。
解决方法:在数据库的配置的url后加useUnicode=true&characterEncoding=UTF-8参数。
private static String URL = "jdbc:mysql://localhost:3306/ki?useUnicode=true&characterEncoding=UTF-8"; private static String USER = "root";
private static String PASSWORD = "root";
用xml配置时,&要使用它的转义符:
<!-- 数据源 --> <bean id="ds" class="org.apache.commons.dbcp.BasicDataSource"> <property name="url" value="jdbc:mysql://localhost:3306/ki?useUnicode=true&characterEncoding=UTF-8"/> <property name="driverClassName" value="com.mysql.jdbc.Driver"/> <property name="username" value="root"/> <property name="password" value="root"/> </bean>
xml的字符转义符:
添加的作用是:指定字符的编码、解码格式。
例如:mysql数据库用的是gbk编码,而项目中用的是utf-8编码。这时候如果添加了useUnicode=true&characterEncoding=UTF-8 ,那么作用有如下两个方面:
存数据时:
数据库在存放项目数据的时候会先用UTF-8格式将数据解码成字节码,然后再将解码后的字节码重新使用GBK编码存放到数据库中。
取数据时:
在从数据库中取数据的时候,数据库会先将数据库中的数据按GBK格式解码成字节码,然后再将解码后的字节码重新按UTF-8格式编码数据,最后再将数据返回给客户端。