MySQL如何确定VARCHAR大小问题

吾爱主题 阅读:147 2024-04-01 23:23:01 评论:0

抛出一个问题,如果需要存字符串到MySQL数据库里面的一张表里的某个字段,如何确定字段的长度大小?

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

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

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

?
1 2 3 4 5 6 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的长度为:

?
1 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大小问题的文章就介绍到这了,更多相关MySQL VARCHAR大小内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_20042935/article/details/122935960

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容