MySQL如何確定VARCHAR大小問(wèn)題
拋出一個(gè)問(wèn)題,如果需要存字符串到MySQL數(shù)據(jù)庫(kù)里面的一張表里的某個(gè)字段,如何確定字段的長(zhǎng)度大???
首先不建議使用TEXT
類型的,因?yàn)槭褂?code>TEXT會(huì)嚴(yán)重影響效率,最好的方式就是使用VARCHAR
并確定字段的最大長(zhǎng)度。
我們可以先在表里定義一個(gè)字段rule_value
,并設(shè)置長(zhǎng)度為255,然后輸入最小的json
字符串進(jìn)去:
使用MySQL的CHAR_LENGTH
函數(shù),計(jì)算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
的長(zhǎng)度為74:
因?yàn)?code>rule_value的值是json
數(shù)組,所以數(shù)組里面的值會(huì)不定變大,這個(gè)時(shí)候,就需要我們?nèi)?wèn)產(chǎn)品確認(rèn),里面的數(shù)組最大有多少個(gè)?
經(jīng)過(guò)詢問(wèn),數(shù)組最大有10個(gè),那么計(jì)算rule_value
的長(zhǎng)度為:
74*10=740
也就是740個(gè)字符,我們可以把之前rule_value
的長(zhǎng)度VARCHAR(255)
改為VARCHAR(740)
即可。
最后需要補(bǔ)充一點(diǎn)知識(shí):
TEXT
最多存65535
個(gè)字符、MEDIUMTEXT
最多存放16777215
個(gè)字符、LONGTEXT
最多存放4294967295
個(gè)字符,不過(guò)一般都不建議使用;- 查看
MySQL
版本命令:select version()
; - 在
MySQL
版本4之前,按字節(jié)來(lái)計(jì)算,版本4之后按字符來(lái)計(jì)算; LENGTH()
返回以字節(jié)為單位的字符串的長(zhǎng)度。CHAR_LENGTH()
返回以字符為單位的字符串的長(zhǎng)度。
到此這篇關(guān)于MySQL如何確定VARCHAR大小問(wèn)題的文章就介紹到這了,更多相關(guān)MySQL VARCHAR大小內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mysql(MyISAM)的讀寫(xiě)互斥鎖問(wèn)題的解決方法
最近因?yàn)閿?shù)據(jù)庫(kù)讀的請(qǐng)求增加,出現(xiàn)了比較嚴(yán)重的讀寫(xiě)鎖問(wèn)題,由于主從分離,主服務(wù)器很快的執(zhí)行完了寫(xiě)入的操作,但從庫(kù)由于有大量的select的查詢,會(huì)被這些來(lái)自主輔同步的update,insert嚴(yán)重堵塞,最后造成所有的Mysql從庫(kù)負(fù)載迅速上升。2011-09-09Can''t connect to MySQL server on ''localhost'' (10048)問(wèn)題解決方
windows 2003服務(wù)器運(yùn)行php的提示Can't connect to MySQL server on 'localhost' (10048), 下面來(lái)看下解決方法2013-09-09淺談mysql的timestamp存在的時(shí)區(qū)問(wèn)題
本文主要介紹了淺談mysql的timestamp存在的時(shí)區(qū)問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07MySQL定時(shí)備份數(shù)據(jù)庫(kù)(全庫(kù)備份)的實(shí)現(xiàn)
本文主要介紹了MySQL定時(shí)備份數(shù)據(jù)庫(kù)(全庫(kù)備份)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09MySQL導(dǎo)出數(shù)據(jù)遇到secure-file-priv問(wèn)題的解決方法
這篇文章主要為大家詳細(xì)介紹了MySQL導(dǎo)出數(shù)據(jù)遇到secure-file-priv問(wèn)題的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10