欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MySQL如何确定VARCHAR大小问题

程序员文章站 2022-04-16 09:18:16
抛出一个问题,如果需要存字符串到mysql数据库里面的一张表里的某个字段,如何确定字段的长度大小?首先不建议使用text类型的,因为使用text会严重影响效率,最好的方式就是使用varchar并确定字...

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

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

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

MySQL如何确定VARCHAR大小问题

使用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:

MySQL如何确定VARCHAR大小问题

因为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大小问题的文章就介绍到这了,更多相关mysql varchar大小内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!