视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MySQL编码不一致导致乱码问题解决
2020-11-09 12:09:24 责编:小采
文档


使用MySQL常常会出现乱码问题,一般情况下都是因为编码不一致造成,以下提供了MySQL数据编码相关的一些信息,希望会有所帮助。一

使用MySQL常常会出现乱码问题,一般情况下都是因为编码不一致造成,以下提供了MySQL数据编码相关的一些信息,希望会有所帮助。

一、MySQL的编码机制:

1、数据库级别的编码:数据库服务器上允许建立不同编码的数据库,在数据库建立时需要指定编码;

2、表级别的编码:同一个数据库中可以建立不同编码的表,在表建立时需要指定编码,默认为用户连接时的编码;

3、表字段级别的编码:同一个表中可以建立不同编码的字段,默认为表的编码,要对字段指定特殊的编码,必须在字段中明确指定编码格式;

4、建立数据库连接时的编码:用户可以在建立数据库连接时指定编码,默认为服务器的配置。

二、出现乱码的一般原因:

1、建立数据库连接时使用的编码不对:例如:数据库编码为UTF-8,连接数据时没有指定编码格式常常会造成乱码问题,正常的解决应该是在driverURL中指定编码 jdbc:mysql://localhost:3306/zhuojh?useUnicode=true&characterEncoding=UTF-8

2、表的编码和driverURL中指定编码不一致造成的乱码问题例如:表的编码是latin1,driverURL中指定编码却是UTF-8,在保存时就会提示保存了错误的数据,解决方式就是使用相同的编码

3、表的编码和表中字段编码不一致造成的乱码问题例如:表的编码是UTF-8,表中的字段却是latin,这种情况编码问题处理起来比较复杂,建议统一编码格式,有兴趣者可以深入研究

三、案例

1、Spring、Hibernate、Struts和Proxool,采用MySQL数据库乱码问题解决:如果表和字段的编码一致都是UTF-8,在Proxool配置中指定下配置项,,即可解决乱码问题 jdbc:mysql://localhost:3306/zhuojh?useUnicode=true&characterEncoding=UTF-8

2、Spring、Struts和iBatis,采用MySQL数据库乱码问题解决:如果表和字段的编码一致都是UTF-8,在属性文件配置中指定下配置项,即可解决乱码问题 jdbc:mysql://localhost:3306/bcq?useUnicode\=true&characterEncoding\=UTF-8

3、Linux下使用MySQL自带的备份工具转换不同编码格式的表数据如果源表的编码格式为latin1,目标表的编码格式为UTF-8,在Linux环境下可以使用以下命令进行转换 mysqldump -C -h ${source_host} -u${source_username} -p${source_password} --default-character-set=latin1 source_database source_tablename|sed -e 's/latin1/utf8/'|mysql -u${local_username} -p${local_password} local_tablename

下载本文
显示全文
专题