原文链接:http://www.javaarch.net/jiagoushi/627.htm
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默认字符集编码,具体操作过程: 好记心不如烂笔头,很多东西当时没记下来,过了忘了,下次用到时又得浪费好多时间才能解决。又遇到修改MySQL默认字符集编码的问题,折腾了半天解决...
今天又遇到修改MySQL默认字符集编码的问题,折腾了半天解决了,赶快记录下来,以后就不用每次折腾了。 查看MySQL字符集的命令是“show variables like ‘%char%’;”。 以MySQL5.6为例,默认的字符集为: 在工作...
linux修改mysql字符集 linux修改mysql字符集
下面小编就为大家介绍两种修改mysql默认字符集的方法。需要的朋友可以过来参考下
MySQL 批量修改SCHEMA下所有数据表的编码及字符集
mysql字符集查看以及修改
安装完的MySQL的默认字符集为 latin1 ,为了要将其字符集改为用户所需要的(比如utf8),就必须改其相关的配置文件;由于linux下MySQL的默认安装目录分布在不同的文件下;不像windows一样放在同一目录下,只需修改其中...
设置mysql字符集 mysql 乱码
关于MySQL字符集查看与修改; MySQL的字符集支持(Character Set Support)有两个方面: 字符集(Character set)和排序方式(Collation)。 MySQL对于字符集的支持细化到四个层次: 服务器(server),数据库(database),...
mysql 字符集 转换
mysql字符集和校对集
Linux下修改MySQL字符集 1.查找MySQL的cnf文件的位置 find / -iname '*.cnf' -print /usr/share/mysql/my-innodb-heavy-4G.cnf /usr/share/mysql/my-large.cnf /usr/share/mysql/my-small.cnf /usr/share/mysql/...
mysql数据库,表 ,字段的字符集设置
精通MySQL字符集与校对集,再也不会为乱码而心烦意乱了
Linux CentOS Mysql修改默认端口.docx
详细的介绍了mysql数据库字符集的设置,有效的避免了乱码的发生
查看mysql字符集MySQL 乱码的根源是的 MySQL 字符
MySQL的字符集支持(Character Set Support)有两个方面: 字符集(Character set)和排序方式(Collation)。 对于字符集的支持细化到四个层次: 服务器(server),数据库(database),数据表(table)和连接(connection)。
Mysql数据库是一个开源的数据库,应用非常广泛。以下是修改mysql数据库的字符编码的操作过程和将表的字符编码转换成utf-8的方法,需要的朋友可以参考下