MySQL字符集LATIN1转UTF8

转载自: http://www.ttlsa.com/html/79.html

导出表结构

1. mysqldump -uroot -p --default-character-set=utf8 -d databasename > db.sql

2. 修改db.sql内的字符集设置(notepad++编辑)
ENGINE=MyISAM DEFAULT CHARSET=latin1;
修改为
ENGINE=MyISAM DEFAULT CHARSET=utf8;

3. 导出数据
mysqldump.exe -uroot -p --quick --no-create-info --extended-insert --default-character-set=latin1 databasename >data.sql
//--default-character-set=latin1,使得导出的数据时中文,而不是乱码,当初改成utf8的做法是错误

4. 修改data.sql
set names latin1;
改为
set names utf8;//使得客户端和链接使用utf8格式,使得数据以utf8的形式存储

5. 创建数据库
create database databasename default charset utf8;

6. 导入表结构

mysql -uroot -p databasename < db.sql

7. 导入表数据
mysql -uroot -p databasename < data.sql

备注:原理流程
1、导出表结构,把latin1结构替换成utf8
2、用原有的latin1导出数据,并且将set names替换成utf8格式
3、创建数据库,默认字符集改成utf8
4、导入表结构、数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值