MySQL怎么确定VARCHAR的大小

网友投稿 601 2023-07-06

MySQL怎么确定VARCHAR的大小

MySQL怎么确定VARCHAR的大小

首先不建议使用TEXT类型的,因为使用TEXT会严重影响效率,最好的方式就是使用VARCHAR并确定字段的最大长度。

我们可以先在表里定义一个字段rule_value,并设置长度为255,然后输入最小的json字符串进去:

使用MySQL的CHAR_LENGTH函数,计算rule_value的大小:

SELECT id,rule_type,rule_value,CHAR_LENGTH(rule_value) as rule_value_length,rule_mark FROM test_tableWHERE rule_type = 'RANDOM_STR'登录后复制

可以看到rule_value的长度为74:

因为rule_value的值是json数组,所以数组里面的值会不定变大,这个时候,就需要我们去问产品确认,里面的数组最大有多少个?

经过询问,数组最大有10个,那么计算rule_value的长度为:

74*10=740登录后复制

也就是740个字符,我们可以把之前rule_value的长度VARCHAR(255)改为VARCHAR(740)即可。

最后需要补充一点知识:

TEXT最多存65535个字符、MEDIUMTEXT最多存放16777215个字符、LONGTEXT最多存放4294967295个字符,不过一般都不建议使用;查看MySQL版本命令:select version();在MySQL版本4之前,按字节来计算,版本4之后按字符来计算;LENGTH()返回以字节为单位的字符串的长度。CHAR_LENGTH()返回以字符为单位的字符串的长度。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:怎么使用dockercompose搭建nginx+mysql+redis+springboot项目
下一篇:kubernetes之怎么使用statefulset搭建MySQL集群
相关文章