MySQL如何確定VARCHAR大小問題

拋出一個問題,如果需要存字符串到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大小內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: