MySQL4.1的latin1编码与中文、藏文乱码解决方案

简介:
+关注继续查看
MySQL4.1中字符串的编码是latin1,对中文、藏文支持都有问题,常常导致乱码。
这个问题明明是MySQL历史遗留的BUG,可是MySQL4已经在运营用中使用,不可能更换数据库来解决,那只能在程序上下功夫了。
 
一、中文乱码问题,这个比较好解决
 
分析latin1的编码实际上对应的是“ISO-8859-1”编码。
Java中,要正确的获取数据库数据显示中文,原理上需要将latin1转换为GBK、GB13080即可,Java从结果集读取getString()的时候,获取的数据实际编码是,实际对应的编码是“ISO-8859-1”。
 
这样就有办法了,读取数据,将数据从“ISO-8859-1”转为“GBK/GB13080”。
方法如下:
1、在JDBC的连接URL后面加上useUnicode=true参数。
2、将读取的结果集转码为GBK,比如:
String x = rs.getString("username"); 
String x1 = new String(xml.getBytes("ISO-8859-1"),"GBK")
 
二、藏文的解决办法
 
实际上,中文的GB2312中已经包含了所有的藏文字符,因此只要将编码转换为"GBK"即可。但是MySQL的JDBC驱动对藏文支持有有问题,只有老版本的mysql-connector-java-3.0.17-ga.zip对藏文支持良好。为此当然选择这个驱动了。
 
那么,自然得到藏文的解决方案:
1、在JDBC的连接URL后面加上useUnicode=true参数。
2、选择mysql-connector-java-3.0.17-ga.zip驱动
3、将读取的结果集转码为GBK,比如:
String x = rs.getString("username"); 
String x1 = new String(xml.getBytes("ISO-8859-1"),"GBK")
 
在网上看到一些解决中文的问题,不少人说修改MySQL5的驱动,可是怎么修改也没发现谁给出代码,经过尝试,MySQL驱动的开发者也不是吃干饭的,你想改就改啊,不容易的。再说改动可能引起新的问题,不是好办法。
 
顺便给大家看看藏文,不过你要想在自己电脑上,需要安装藏文字体:
 
 
 
欢迎交流此问题。


本文转自 leizhimin 51CTO博客,原文链接:http://blog.51cto.com/lavasoft/235274,如需转载请自行联系原作者
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4月前
|
SQL 存储 数据可视化
【解决方案 二】---设置mysql5.7编码集为utf8mb4
【解决方案 二】---设置mysql5.7编码集为utf8mb4
199 0
|
5月前
|
存储 SQL 数据可视化
从零开始学Mysql - 字符集和编码(下)
​ 这个系列的文章是根据《MySQL是怎样运行的:从根儿上理解MySQL》这本书的个人笔记总结专栏,这里十分推荐大家精读一下这本书,也是目前市面上个人所知的讲述Mysql原理的为数不多的好书之一,好了废话不多说我们下面进入正题。
67 0
|
5月前
|
存储 SQL 编解码
从零开始学Mysql - 字符集和编码(上)
​ 上一节我们系统的阐述了关于系统配置的相关细节内容,而这一节我们需要了解关于字符集和编码的内容,字符集和编码的规则其实也算是入门mysql经常遇到的一个坑,基本每个人学习过程必定会遇到数据库存储中文但是读出来是:“???”的这种问题,好了废话不多说,我们来看下mysql的字符集和编码的规则。
49 0
|
6月前
|
关系型数据库 MySQL
MySQL的校对规则设置为 utf8mb4_unicode_ci是干什么的?底层原理是什么?
MySQL的校对规则设置为 utf8mb4_unicode_ci是干什么的?底层原理是什么?
|
10月前
|
数据库
数据库写入中文乱码问题 编码latin1解决方法
数据库写入中文乱码问题 编码latin1解决方法
95 0
|
存储 SQL 关系型数据库
从零开始学Mysql - 字符集和编码(上)(二)
从零开始学Mysql - 字符集和编码(上)(二)
479 0
|
存储 编解码 关系型数据库
从零开始学Mysql - 字符集和编码(上)(一)
从零开始学Mysql - 字符集和编码(上)(一)
101 0
|
存储 架构师 关系型数据库
总结:被MySQL UTF8编码坑的惨痛教训...
最近遇到几个项目被MySQL的utf8编码坑,想起之前编码问题被坑的惨痛教训,记录一下,警示自己。曾几何时,每次建库都选utf8,觉得自己比那些用乱七八糟编码的人不知道酷到哪里去了。
|
存储 关系型数据库 MySQL
解决mysql存储特殊文字(表情符号)utf8mb4
一、背景 爬取数据过程中,会遇到一些特殊的字符入库出错的问题,比如二进制数据、比如特殊文字(类似QQ表情)等。 Siberian Husky fighting 这样的标题,后面就带有一个表情。
4003 0
|
MySQL 关系型数据库 Linux
推荐文章
更多