您现在的位置是:网站首页> 编程资料编程资料
MySQL如何确定VARCHAR大小问题_Mysql_
2023-05-26
413人已围观
简介 MySQL如何确定VARCHAR大小问题_Mysql_
抛出一个问题,如果需要存字符串到MySQL数据库里面的一张表里的某个字段,如何确定字段的长度大小?
首先不建议使用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大小问题的文章就介绍到这了,更多相关MySQL VARCHAR大小内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- mysql中#{}和${}的区别详解_Mysql_
- 教你如何让spark sql写mysql的时候支持update操作_Mysql_
- 一文弄懂MySQL中redo log与binlog的区别_Mysql_
- Mysql Innodb存储引擎之索引与算法_Mysql_
- 深入讲解数据库中Decimal类型的使用以及实现方法_Mysql_
- Mysql分库分表之后主键处理的几种方法_Mysql_
- MySQL 开窗函数_Mysql_
- mysql自增长id用完了该怎么办_Mysql_
- mysql下的max_allowed_packet参数设置详解_Mysql_
- mysql聚集索引、辅助索引、覆盖索引、联合索引的使用_Mysql_
