常用命令
- 查看建表DDL
show create table table_name;
- 查看字符编码
show variables like 'character%';
-- character_set_client
-- character_set_connection
-- character_set_database
-- character_set_filesystem
-- character_set_results
-- character_set_server
-- character_set_system
索引
- join的两张表,如果字符编码不一样会导致索引失效。
- varchar(20)的一个column 如果建立索引,utf8索引长度是60bytes,utf8mb4索引长度是80bytes。因为索引是根据字符集的最大长度来创建的。
- 如果对字符串列进行索引,只要有可能,尽量指定前缀长度,即使用前缀索引。
- InnoDB 索引最大字节数是 768 bytes。
utf8 升级 utf8mb4
- JAVA 驱动
- MySQL驱动版本要在 5.1.13 及以上版本。
- 数据库连接依然是 characterEncoding=utf8 。
- MySQL Server 端需要设置 character_set_server=utf8mb4。 Java驱动会自动检测服务端 character_set_server 的配置,如果为utf8mb4,驱动在建立连接的时候设置 SET names utf8mb4。
Connector/J did not support utf8mb4 for servers 5.5.2 and newer.
Connector/J now auto-detects servers configured with character_set_server=utf8mb4 or treats the Java encoding utf-8 passed
using characterEncoding=… as utf8mb4 in the SET NAMES= calls it makes when establishing the connection. (Bug #54175)
- 客户端
SET names 'utf8mb4' COLLATE 'utf8mb4_unicode_ci';
-- 会同时修改 character_set_client / character_set_connection / character_set_results 这3个参数的值。