mysql修改表默认字符集可能带来的隐患
2013-05-29 13:35
417 查看
原文链接:http://www.javaarch.net/jiagoushi/627.htm
mysql修改表默认字符集可能带来的隐患
我们在建表后如果后续需要修改表的默认字符集,可以通过ALTER TABLE来修改表的默认编码
1. ALTER TABLE tablename DEFAULT CHARACTER SET utf8;
但是这样有个问题,只改了表定义的默认编码,对于每个列的已有字段的内容还是使用以前的编码,已有表数据不会做编码转换。
然后我们插入一个多字节的字符串记录到表里
我们可以看到列subject还是big5编码,没有改为utf8编码。
我们可以使用2. ALTER TABLE tablename CONVERT TO CHARACTER SET utf8;来修改列的编码
但是这里要注意已有内容编码转换要注意编码可转换,不会成为乱码
mysql修改表默认字符集可能带来的隐患
我们在建表后如果后续需要修改表的默认字符集,可以通过ALTER TABLE来修改表的默认编码
1. ALTER TABLE tablename DEFAULT CHARACTER SET utf8;
但是这样有个问题,只改了表定义的默认编码,对于每个列的已有字段的内容还是使用以前的编码,已有表数据不会做编码转换。
mysql> create table mybig5 (id int not null auto_increment primary key, -> subject varchar(100) ) engine=innodb default charset big5; Query OK, 0 rows affected (0.81 sec) mysql> show create table mybig5; +--------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | Table | Create Table | +--------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | mybig5 | CREATE TABLE `mybig5` ( `id` int(11) NOT NULL AUTO_INCREMENT, `subject` varchar(100) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=big5 | +--------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+ 1 row in set (0.00 sec) mysql> alter table mybig5 default charset utf8; Query OK, 0 rows affected (0.17 sec) Records: 0 Duplicates: 0 Warnings: 0
然后我们插入一个多字节的字符串记录到表里
mysql> INSERT INTO mybig5 VALUES (NULL, UNHEX('E7BB8FE79086')); 01:08:19 [INSERT - 0 row(s), 0.000 secs] [Error Code: 1366, SQL State: HY000] Incorrect string value: '\xE7\xBB\x8F\xE7\x90\x86' for column 'SUBJECT' at row 1 ... 1 statement(s) executed, 0 row(s) affected, exec/fetch time: 0.000/0.000 sec [0 successful, 0 warnings, 1 errors] mysql> show create table mybig5; +--------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | Table | Create Table | +--------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | mybig5 | CREATE TABLE `mybig5` ( `id` int(11) NOT NULL AUTO_INCREMENT, `subject` varchar(100) CHARACTER SET big5 DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 | +--------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ 1 row in set (0.00 sec)
我们可以看到列subject还是big5编码,没有改为utf8编码。
我们可以使用2. ALTER TABLE tablename CONVERT TO CHARACTER SET utf8;来修改列的编码
mysql> show create table mybig5; mysql> +--------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+ -> | Table | Create Table | -> +--------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+ -> | mybig5 | CREATE TABLE `mybig5` ( -> `id` int(11) NOT NULL AUTO_INCREMENT, -> `subject` varchar(100) DEFAULT NULL, -> PRIMARY KEY (`id`) -> ) ENGINE=InnoDB DEFAULT CHARSET=utf8 | -> +--------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+ -> 1 row in set (0.00 sec)
但是这里要注意已有内容编码转换要注意编码可转换,不会成为乱码
相关文章推荐
- mysql修改表默认字符集可能带来的隐患
- 修改mysql默认字符集的方法
- Ubuntu MySQL修改默认Engine和字符集
- 修改mysql的字符集和默认存储引擎
- MySQL:修改默认字符集,转换字符集(MySQL 5.X)
- 修改mysql默认字符集的方法
- 修改mysql默认字符集的方法
- MySQL修改默认字符集
- MAC下修改mysql默认字符集为utf8的方法
- 修改mysql默认字符集的方法
- 修改mysql默认字符集的方法
- suse linux 下MYSQL 修改默认字符集
- 修改mysql默认字符集的两种方法详细解析
- 修改mysql默认字符集的方法
- 修改mysql默认字符集的方法
- mysql默认字符集的修改方法
- mac pro 安装mysql并且配置my.cnf(添加默认字符集utf8,数据存放路径,修改已经建好的表的默认字符集等)、mac mysql my.cnf路径
- [Mysql]修改默认字符集
- mac下安装MySql,修改root密码,配置环境变量,设置默认字符集(mysql5.7.13)
- MySQL修改默认字符集---通过命令行