免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1993 | 回复: 3
打印 上一主题 下一主题

数据库编码问题求教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-05 10:34 |只看该作者 |倒序浏览
数据库默认编码CHARSET=latin1;

假设备份数据库 mysqldump --opt demo >demo.sql


新服务器 mysql默认编码是utf8


mysql demo<demo.sql 这样导入备份的数据库是有问题的。请教如何把demo.sql数据库到入道utf8编码的数据库中呢?

论坛徽章:
0
2 [报告]
发表于 2011-12-05 10:53 |只看该作者
回复 1# 无语的奇迹


    这是我以前学习时候的笔记,你可以按照对应的步骤操作。

Mysql 字符集的修改步骤
如果在应用开始阶段没有正确的设置字符集,在运行一段时间以后才发现 存在不能满足要求需要调整,又不想丢弃这段时间的数据,那么就需要进行字符集的修改。 字符集的修改不能直接通过 alter
dataabase character set *** 或者 alter table tablename character set ***; 命令进行,这两个命令都没有更新已有记录的字符集, 而只是对新创建的表或者记录生效。
已有的记录的字符集调整,需要先将数据导出,经过适当的调整重新导入后才可完成。
以下模拟的是将latin1字符集的数据库修改成GBK字符集的数据库的过程。
1> 导出表结构:
mysqldump -uroot -p --default-character-set=gbk -d databasename > createtab.sql
其中 --default-character-set=gbk 表示设置以什么字符集连接, -d 表示只导出表结构,不导出数据。
2>手工修改 createtab.sql 中表结构定义中的字符集为新的字符集。
3>确保记录不再更新,导出所有记录。
mysqldump -uroot -p --quick --no-create-info --extended-insert --default-character-set=latin1 databasename > data.sql
--quick: 该选项用于转储大的表。 它强制 mysqldump 从服务器一次一行地检索表中的行而不是 检索所有行,并在输出前将它缓存到内存中。
--extended-insert: 使用包括几个 values 列表的多行insert语法,这样使转储文件更小,重载文件时可以加速插入。
--no-create-info: 不写重新创建每个转储表的create table 语句。
--default-character-set=latin1: 按照原有的字符集导出所有数据,这样导出的文件中,所有中文都是可见的,不会保存成乱码。
4>打开data.sql,将 set names latin1 修改成 set names gbk 。
5>使用新的字符集创建新的数据库。
create database databasename default charset gbk;
6>创建表,执行 createtab.sql
mysql -uroot -p databasename < createtab.sql
7>导入数据,执行data.sql
mysql -uroot -p databasename < data.sql

论坛徽章:
0
3 [报告]
发表于 2011-12-05 10:58 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
4
CU大牛徽章
日期:2013-03-13 15:32:35CU大牛徽章
日期:2013-03-13 15:38:15CU大牛徽章
日期:2013-03-13 15:38:52戌狗
日期:2013-12-27 15:08:11
4 [报告]
发表于 2011-12-05 11:00 |只看该作者
数据库量不是很大的话,我觉得可以先在备份数据库中用sql建好库,然后用文本工具打开demo.sql,复制insert语句到备份数据库里执行,i操作时注意字符集的更改。时注意麻烦是麻烦了点
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP