MySQL怎么确定VARCHAR的大小
导读:本文共1201.5字符,通常情况下阅读需要4分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: 首先不建议使用TEXT类型的,因为使用TEXT会严重影响效率,最好的方式就是使用VARCHAR并确定字段的最大长度。我们可以先在表里定义一个字段rule_value,并设置长度为255,然后输入最小的json字符串进去:使用MySQL的CHAR_LENGTH函数,计算rule_value的大小:SELECTid,rule_type,rule_value,CHA... ...
目录
(为您整理了一些要点),点击可以直达。首先不建议使用TEXT
类型的,因为使用TEXT
会严重影响效率,最好的方式就是使用VARCHAR
并确定字段的最大长度。
我们可以先在表里定义一个字段rule_value
,并设置长度为255,然后输入最小的json
字符串进去:
使用MySQL的CHAR_LENGTH
函数,计算rule_value
的大小:
SELECTid,rule_type,rule_value,CHAR_LENGTH(rule_value)asrule_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()
返回以字符为单位的字符串的长度。
</div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
MySQL怎么确定VARCHAR的大小的详细内容,希望对您有所帮助,信息来源于网络。