MySQL 问题汇总

这篇博客总结了MySQL的常用命令,如查看建表DDL和字符编码。讨论了索引的细节,强调了不同字符集对索引长度的影响,并建议使用前缀索引以节省空间。还提到了从utf8升级到utf8mb4的过程,特别是对于JAVA驱动和MySQL Server的版本及配置要求。
摘要由CSDN通过智能技术生成

常用命令

  1. 查看建表DDL
show create table table_name;
  1. 查看字符编码
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

  1. 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)

  1. 客户端
SET names 'utf8mb4' COLLATE 'utf8mb4_unicode_ci';
-- 会同时修改 character_set_client / character_set_connection / character_set_results 这3个参数的值。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值