MySQL如何確定VARCHAR大小問題
拋出一個問題,如果需要存字符串到MySQL數(shù)據(jù)庫里面的一張表里的某個字段,如何確定字段的長度大???
首先不建議使用TEXT類型的,因為使用TEXT會嚴重影響效率,最好的方式就是使用VARCHAR并確定字段的最大長度。
我們可以先在表里定義一個字段rule_value,并設(shè)置長度為255,然后輸入最小的json字符串進去:

使用MySQL的CHAR_LENGTH函數(shù),計算rule_value的大?。?/p>
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數(shù)組,所以數(shù)組里面的值會不定變大,這個時候,就需要我們?nèi)柈a(chǎn)品確認,里面的數(shù)組最大有多少個?
經(jīng)過詢問,數(shù)組最大有10個,那么計算rule_value的長度為:
74*10=740
也就是740個字符,我們可以把之前rule_value的長度VARCHAR(255)改為VARCHAR(740)即可。
最后需要補充一點知識:
TEXT最多存65535個字符、MEDIUMTEXT最多存放16777215個字符、LONGTEXT最多存放4294967295個字符,不過一般都不建議使用;- 查看
MySQL版本命令:select version(); - 在
MySQL版本4之前,按字節(jié)來計算,版本4之后按字符來計算; LENGTH()返回以字節(jié)為單位的字符串的長度。CHAR_LENGTH()返回以字符為單位的字符串的長度。
到此這篇關(guān)于MySQL如何確定VARCHAR大小問題的文章就介紹到這了,更多相關(guān)MySQL VARCHAR大小內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Can''t connect to MySQL server on ''localhost'' (10048)問題解決方
windows 2003服務(wù)器運行php的提示Can't connect to MySQL server on 'localhost' (10048), 下面來看下解決方法2013-09-09
MySQL定時備份數(shù)據(jù)庫(全庫備份)的實現(xiàn)
本文主要介紹了MySQL定時備份數(shù)據(jù)庫(全庫備份)的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
MySQL導出數(shù)據(jù)遇到secure-file-priv問題的解決方法
這篇文章主要為大家詳細介紹了MySQL導出數(shù)據(jù)遇到secure-file-priv問題的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10

