mysql建表的时候设置表里面的字段的字符集是utf-8要怎么设置?默认建好后我去mysql里看字符集都是gbk

mysql建表的时候设置表里面的字段的字符集是utf-8要怎么设置?默认建好后我去mysql里看字符集都是gbk,第1张

1、建表时指定字符集utf-8:

CREATETABLE 表名

( `id`TINYINT(255)UNSIGNEDNOTNULLAUTO_INCREMENTPRIMARYKEY,

`content`VARCHAR(255)NOTNULL)

DEFAULTCHARACTERSET=utf8

2、修改表的字符集为utf-8:

altertable表名converttocharactersetutf8

扩展资料:

1、创建数据库时设置字符集:

CREATEDATABASE 数据库名CHARACTERSETutf8COLLATEutf8_general_ci

注意后面三个单词之间是有下划线的对于每个选项所给定的值,前面没有等号;在第一个选项和第二个选项之间也没有逗号。

2、修改数据库的字符集:

alterdatabase 数据库名charactersetutf8

3、显示某数据库字符集设置:

showcreatedatabase数据库名

4、显示某数据表字符集设置:

showcreatetable表名

5、修改字段:

altertable表名modifycolumn'字段名'varchar(30)charactersetutf8notnull

6、添加表字段:

altertable表名addcolumn'字段名'varchar(20)charactersetutf8

理论上说起来,设置为 utf8 也并非一个完全合适、100% 没毛病的值,即便你将 MySQL 的字符集设置为 utf8 ,也有可能出现乱码!

通过以下命令,你可以查看 MySQL 所支持的所有『字符集』编码:

在显示的 Charset ,你会看见熟悉的 utf8

如果你再仔细看一下这一行,你会发现这一行的 Maxlen 列中的值居然是 3 !?

这是 MySQL 中的 utf8 并非我们现在常说的 『真·UTF8』 。它『 最多 』只用 3 个字节存储一个字符,而有些中日韩生僻字<small>(包括 emoji 表情)</small>的 Unicode 编码是需要 4 个字节宽度才能存储的,这就会导致一些乱码的隐患。

MySQL 解决这个问题的方案是绕过 utf8 提出一种新的字符集来实现 『 真·UTF8 』 功能: utf8mb4

实际上,为了统一称呼,MySQL 在提出 utf8mb4 字符集之后,就将 utf8 改为 utf8mb3 的别名,因此,你设置字符集为 utf8 本质上就是设置成了 utf8mb3

在更高版本(8.x)的 mysql 中,MySQL 直接将 utf8 改为了 utfmb4 的别名。

1、MySQL默认的字符集是UTF8;

2、对于字符集的支持细化到四个层次:服务器(server),数据库(database),数据表(table)和连接(connection)。

3、具体的字符集可以通过修改配置文件(my.cnf)进行调整。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7213660.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-03
下一篇 2023-04-03

发表评论

登录后才能评论

评论列表(0条)

保存