首先不建议使用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_table WHERE 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()返回以字符为单位的字符串的长度。
以上就是MySQL怎么确定VARCHAR的大小的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号