怎么修改表以及字段的编码

MySql 码拜 9年前 (2016-02-06) 1461次浏览
有表A,创建时的编码为utf8,现在改成gbk,执行ALTER TABLE A DEFAULT CHARACTER SET gbk;
然后查看表的编码: SHOW CREATE TABLE A;
CREATE TABLE `A` (
`username` char(10) CHARACTER SET utf8 DEFAULT NOT NULL,
`password` varchar(32) CHARACTER SET utf8 NOT NULL,
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
问一下怎么样修改表编码的同时将字段的编码也一并修改
解决方案

40

没那么麻烦,一句SQL搞定.这也是各DBMS有些不太相同的地方.

mysql> CREATE TABLE `A` (
    ->    `username` char(10) CHARACTER SET utf8 NOT NULL,
    ->    `password` varchar(32) CHARACTER SET utf8 NOT NULL
    ->  ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
Query OK, 0 rows affected (0.01 sec)
mysql>
mysql> ALTER TABLE `A` DEFAULT CHARACTER SET gbk ,
    ->     modify `username` char(10) CHARACTER SET gbk NOT NULL,
    ->     modify `password` varchar(32) CHARACTER SET gbk NOT NULL;
Query OK, 0 rows affected (0.02 sec)
Records: 0  Duplicates: 0  Warnings: 0
mysql> show create table `A`;
+--+--+
| Table | Create Table
                               |
+--+--+
| A     | CREATE TABLE `a` (
  `username` char(10) NOT NULL,
  `password` varchar(32) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=gbk |
+--+--+
1 row in set (0.00 sec)
mysql>

其实官方文档上也都有参考.看明白了就行.


CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明怎么修改表以及字段的编码
喜欢 (0)
[1034331897@qq.com]
分享 (0)