最近在研究MySQL的数据类型,咱们知道,选择合适的数据类型和数据长度对MySQL的性能影响是不可忽视的,小字段意味着能够MySQL能够读取更多的记录,从而加快查询速度。sql
网上该问题的答案有不少版本,仍是经过实践得出的结论比较靠谱。性能
先说结论(MySQL版本5.7.27)spa
VARCHAR最大65535字节,字符集对VARCHAR有影响code
UTF8字符集(1个字符占用3个字节)ci
CREATE TABLE `test`.`demo` ( `id` int(0) UNSIGNED NULL AUTO_INCREMENT, `title` char(256) NULL, PRIMARY KEY (`id`) ) CHARACTER SET = utf8 COLLATE = utf8_general_ci;
MySQL提示错误rem
1074 - Column length too big for column 'title' (max = 255); use BLOB or TEXT instead
GBK字符集(1个字符占用2个字节)get
CREATE TABLE `test`.`demo` ( `id` int(0) UNSIGNED NULL AUTO_INCREMENT, `title` char(256) NULL, PRIMARY KEY (`id`) ) CHARACTER SET = gbk COLLATE = gbk_chinese_ci;
MySQL提示错误it
1074 - Column length too big for column 'title' (max = 255); use BLOB or TEXT instead
结论:CHAR最大长度和字符集没有关系,所以CHAR()括号内填写字符大小,最终数据的字节大小随着字符集不一样而不一样
UTF8字符集(1个字符占用3个字节)class
CREATE TABLE `test`.`demo` ( `id` int(0) UNSIGNED NULL AUTO_INCREMENT, `title` varchar(65535) NULL, PRIMARY KEY (`id`) ) CHARACTER SET = utf8 COLLATE = utf8_general_ci;
MySQL提示错误test
1074 - Column length too big for column 'title' (max = 21845); use BLOB or TEXT instead
MySQL提示的最大长度为21845,经过UTF8字符集的大小可知VARCHAR()括号中指的是字符大小。
UTF8MB4字符集(1个字符占用4个字节)
CREATE TABLE `test`.`demo` ( `id` int(0) UNSIGNED NULL AUTO_INCREMENT, `title` varchar(65535) NULL, PRIMARY KEY (`id`) ) CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci;
MySQL提示错误
1074 - Column length too big for column 'title' (max = 16383); use BLOB or TEXT instead
MySQL提示的最大长度为16383,经过UTF8MB4字符集大小可知VARCHAR()括号中指的是字符大小。
更多原创文章,尽在天天进步一点点