我在 Ubuntu 18.04 上使用 MySQL 和 MySQL Workbench 8.0+。当我创建字符串类型的列时,我将字符集/排序规则保留为默认值。在 MySQL Workbench 中,它只是告诉我就是这样Default Charset
.
我当前的 MySQL 和 Workbench 使用的默认字符集是什么?我怎样才能弄清楚这一点?
Use SHOW CREATE TABLE
。例如:
CREATE TABLE a (
dflt VARCHAR(11),
cs VARCHAR(11) CHARACTER SET latin1,
cola VARCHAR(11) COLLATE utf8mb4_hungarian_ci,
cc VARCHAR(11) CHARACTER SET latin1 COLLATE latin1_bin,
colb VARCHAR(11) COLLATE latin1_bin
);
SHOW CREATE TABLE a\G
mysql> SHOW CREATE TABLE a\G
*************************** 1. row ***************************
Table: a
Create Table: CREATE TABLE `a` (
`dflt` varchar(11) DEFAULT NULL,
`cs` varchar(11) CHARACTER SET latin1 COLLATE latin1_swedish_ci DEFAULT NULL,
`cola` varchar(11) CHARACTER SET utf8mb4 COLLATE utf8mb4_hungarian_ci DEFAULT NULL,
`cc` varchar(11) CHARACTER SET latin1 COLLATE latin1_bin DEFAULT NULL,
`colb` varchar(11) CHARACTER SET latin1 COLLATE latin1_bin DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
Notes:
- 大多数列都阐明了字符集和排序规则。
- 那个没有(
dflt
)从继承这些设置DEFAULTs
对于桌子。
- Each
CHARACTER SET
有一个“默认”排序规则。
- Each
COLLATE
恰好与一个相关联CHARACTER SET
,即排序规则名称的第一部分。
- (此处未显示):
DEFAULTs
该表继承自DATABASE
.
- MySQL 8 默认为
CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
如果你什么都不做。
- 旧版本默认为
CHARSET=latin1 COLLATE=latin1_swedish_ci
- 某些排序规则中的“0900”或“520”是指 Unicode 标准版本 9.0 和 5.20。您可以由此推断,将来可能会有新的、“更好”的排序规则。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)