最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

mysql修改表默认字符集可能带来的隐患_MySQL

来源:动视网 责编:小采 时间:2020-11-09 18:36:13
文档

mysql修改表默认字符集可能带来的隐患_MySQL

mysql修改表默认字符集可能带来的隐患_MySQL:bitsCN.com mysql修改表默认字符集可能带来的隐患 我们在建表后如果后续需要修改表的默认字符集,可以通过ALTER TABLE来修改表的默认编码 ALTER TABLE tablename DEFAULT CHARACTER SET utf8;但是这样有个问题,只改了表定义的默认编码,对于每个列的
推荐度:
导读mysql修改表默认字符集可能带来的隐患_MySQL:bitsCN.com mysql修改表默认字符集可能带来的隐患 我们在建表后如果后续需要修改表的默认字符集,可以通过ALTER TABLE来修改表的默认编码 ALTER TABLE tablename DEFAULT CHARACTER SET utf8;但是这样有个问题,只改了表定义的默认编码,对于每个列的


bitsCN.com

mysql修改表默认字符集可能带来的隐患

我们在建表后如果后续需要修改表的默认字符集,可以通过ALTER TABLE来修改表的默认编码

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)

但是这里要注意已有内容编码转换要注意编码可转换,不会成为乱码

bitsCN.com

文档

mysql修改表默认字符集可能带来的隐患_MySQL

mysql修改表默认字符集可能带来的隐患_MySQL:bitsCN.com mysql修改表默认字符集可能带来的隐患 我们在建表后如果后续需要修改表的默认字符集,可以通过ALTER TABLE来修改表的默认编码 ALTER TABLE tablename DEFAULT CHARACTER SET utf8;但是这样有个问题,只改了表定义的默认编码,对于每个列的
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top