数据库中怎么将汉字gbk转utf

数据库中怎么将汉字gbk转utf,第1张

数据库中怎么将汉字gbk转utf

MySQL中的表

数据原来是GBK

就是GBK的编码

变成

UTF8

的途径就是重新导出数据

在导入

并将

myini

中的

配置文件

改为:

两个default-character-set

依次设置为

default-character-set=UTF-8

default-character-set=GBK

应该编码转换的时候丢失了字节,你没有发现你输入的是偶数个字的时候正常,奇数个的时候乱码,具体的字码长度我也不是很了解

String str1 = new String(strgetBytes("UTF-8"),"GBK");

Systemoutprintln(str1length());

String str2 = new String(str1getBytes("GBK"),"UTF-8");

Systemoutprintln(str2length());); 打印出来的字符串长度就不一样的

UTF8每个汉字占用3个字节,这样在某些地方文字个数的计算就和GBK编码的不一样,UTF-8使用可变长度字节来储存 Unicode字符,例如ASCII字母继续使用1字节储存,重音文字、希腊字母或西里尔字母等使用2字节来储存,而常用的汉字就要使用3字节。辅助平面字符则使用4字节。 GB 18030标准采用单字节、双字节和四字节三种方式对字符编码。单字节部分使用0×00至0×7F码(对应于ASCII码的相应码)。双字节部分,首字节码从0×81至0×FE,尾字节码位分别是0×40至0×7E和0×80至0×FE。四字节部分采用GB/T 11383未采用的0×30到0×39作为对双字节编码扩充的后缀,这样扩充的四字节编码,其范围为0×81308130到0×FE39FE39。其中第一、三个字节编码码位均为0×81至0×FE,第二、四个字节编码码位均为0×30至0×39。

按照程序员的称呼,GB2312、GBK到GB18030都属于双字节字符集 (DBCS)。

把configphp中的$_SC['dbcharset'] = 'utf8';修改为$_SC['dbcharset'] = 'gbk';

然后再后台备份数据,再上传gbk的程序把备份好的数据放在/data/backup_/到后台恢复。

切记操作前先不要改configphp文件备份下数据库

uc也要转换为gbk,以及uc下所有应用都要转换为gbk,不然容易产生乱码的情况

Eclipse如何更改项目编码格式UTF-8和GBK互转?手把手教学,一点即通。

打开Eclipse创建相应的项目,或者导入项目到我们的工作目录。

选择菜单栏找到窗口(Window)选项,点击。

看到Window展开的菜单栏选择Preferences点击

打开Preferences后找到General选项,单击展开子菜单。

在General子菜单栏找到Workspce选项,单击打开。

打开后可以看到默认编码格式Txt file encoding 默认的是GBK。我们选择Other选择我们需要的编码即可。

当前安装版本为:dedecms v57 utf8,

目标将网站由UTf8版本转换为GBK版。

2

写在转换之前:

要转换dede系统的版本,实际上是编码的转换的问题,要将mysqls数据从utf8转换为gbk编码,将模板文件的编码也要转换为GBK模式。

在本文中两个核心工具,帝国备份王和Editplus 编辑器。

用ebak2008工具的备份/恢复功能,巧妙dede数据库utf-8编码的无错转换为gbk编码格式。

站点文件的转换就用Editplus 编辑器。

END

二数据的备份

1

在转换之前,将dede做整站备份,备份内容包括mysql数据库,dede站点文件,如果网站容量非常大的话,可以登录php空间管理后台将整个网站进行打包,然后下载。

备份的目的就是了防止转换失败后还有退路。

登录dede后台,选择“系统 ”中 “数据库备份/还原 ”备份dede数据库。

2

备份完毕,请登录ftp下载到本地电脑保存。

Dede备份数据存储位置:/data/backupdata

END

三数据库编码转换

1

解压缩ebak2008,将ebak2008文件夹上传到网站空间的根目录。

用帝国备份王(ebak2008)反向操作,强制转换dedecms v57 utf8版本的mysql数据编码为gbk。

2

打开帝国备份王(ebak2008)工具(地址为:原域名/ebak2008),登陆

3

在登陆后的帝国备份王界面,点击“备份数据”,

4

备份数据界面,选择要备份的数据库,请注意操作,别选错了。

5

非常重要!php虚拟主机安装的dede系统是utf8版,在备份的时候不能选择 “utf8编码进行备份 ”。在这里要反向操作(如果是utf8就选gbk,如果是gbk就选utf8)。

备份时请特别注意:选择数据库编码为gbk,不能选择其它方式,否则在转换后会出现乱码。

数据存储目录命名为:date_gbk_20150618160956。一般用默认的就可以了。

点击,屏幕最下方的 开始备份 ,等待完成操作!

END

四将gbk格式的dede数据库备份恢复到系统

登陆主机ftp后台,将原来的dedecms的目录dede,改为deded_utf8_bak

上传DedeCMS-V57-GBK-SP1tar,到主机后台进行解压缩,将其中的uploads文件夹改为dede,移动到public_html/目录中,此操作可以节省大量上传的时间

接着就可以重新安装dede系统了,安装过程不作演示

在安装DedeCMS-V57-GBK-SP1版时,按默认安装即可。安装完毕后,进后台将插件之类的也重新安装好

然后登录ebak2008数据库备份工具,选择“数据恢复”,恢复第二步骤中将utf8编码强制转换为gbk格式的数据库(date_gbk_20150618160956)。

帝国备份王(ebak2008)恢复数据仅需要50秒左右,速度相当的快。恢复数据后,请登录dede管理后台,重新生成一下网页。

检查首页无乱码,织梦网站管理系统(dedecms)utf8成功转换gbk。

进入网站管理后台,检查数据库表,Mysql数据表无乱码:

转换成功后的小错误,由于dede默认的utf8和gbk版本的差别,在转换成功后,“图文资讯”和“首页幻灯片”丢失,丢失的重新上传一下就OK!整个过程无报错,显示正常

再次进入主机后台找到dede_utf8_bak目录下的uploads下的alimg目录(这个目录就是首页和上传的存放的位置),把这个目录加入到剪贴板,

再进入dede目录下的uploads,复制剪贴板的文件到这里,这样就恢复正常了

本站使用的是dede默认的模板,所以在转换的时候没有改动dede的模板文件,如果你的网站对DEDE的一些文件没有改动,直接按照我的方法就可以成功转换。

如果有改动的文件,请将你改动的文件转换为gbk编码。

用Editplus 编辑器将站点文件中的utf8转换为gbk编码。

重点是dede模板文件编码的转换,细心的用Editplus 编辑器修改,完毕后,上传覆盖即可。

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » 数据库中怎么将汉字gbk转utf

0条评论

发表评论

提供最优质的资源集合

立即查看 了解详情