MYSQL中 char 和 varchar的区别


当前第2页 返回上一页

innodb引擎的每个索引列长度限制为767字节(bytes),所有组成索引列的长度和不能大于3072字节。注意是字节,varchar(256)在不同的编码字节计算不同。例如在utf8mb4中,一个字符占4个字节,256个字符=1024个字节。就达不到索引覆盖的效果噢。相当于只做了一个前缀索引(非常重要,前缀索引是需要回(主键)表的,二次查询)

innodb引擎可以通过配置innodb_large_prefix=on(全局参数,动态生效)来让单个索引列长度限制上升到3072字节

  • 在MySQL5.7里默认 innodb_large_prefix=1 解除了767bytes长度限制,但是单列索引长度最大还是不能超过3072bytes
  • 在MySQL5.6里默认 innodb_large_prefix=0 限制单列索引长度不能超过767bytes。需要设置innodb_large_prefix=ON、innodb_file_format=barracuda、innodb_file_per_table=ON ,且Innodb表的存储格式为 DYNAMIC 或 COMPRESSED,则前缀索引最多可包含3072个字节

以上就是MYSQL中 char 和 varchar的区别的详细内容,更多关于MYSQL char 和 varchar的资料请关注其它相关文章!


标签:SQL

返回前面的内容

相关阅读 >>

删除索引的sql语句是什么

sql server中实现最短路径搜索的解决方法

数据库和sql是什么?两者的优势是什么

sql max用法是什么

java嵌入数据引擎从sqlite到spl详解

sqlserver 注释符 单行注释与多行注释

用asp.net还原与恢复sql server

mysql数据库使用规范总结

如何通过sql语句用一张表更新另一张表

sql语言容易学吗?

更多相关阅读请进入《sql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...