Maison  >  Article  >  base de données  >  Comment MySQL détermine-t-il la taille de VARCHAR

Comment MySQL détermine-t-il la taille de VARCHAR

王林
王林avant
2023-05-27 21:20:051257parcourir

Tout d'abord, il n'est pas recommandé d'utiliser le type TEXT, car l'utilisation de TEXT affectera sérieusement l'efficacité. La meilleure façon est d'utiliser VARCHAR. > et déterminez la taille maximale de la longueur du champ. TEXT类型的,因为使用TEXT会严重影响效率,最好的方式就是使用VARCHAR并确定字段的最大长度。

我们可以先在表里定义一个字段rule_value,并设置长度为255,然后输入最小的json字符串进去:

Comment MySQL détermine-t-il la taille de VARCHAR

使用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:

Comment MySQL détermine-t-il la taille de VARCHAR

因为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()

    Nous pouvons d'abord définir un champ rule_value dans le tableau, définir la longueur à 255, puis saisir la plus petite chaîne json :
Comment MySQL détermine-t-il la taille de VARCHAR🎜🎜Utilisez la fonction CHAR_LENGTH de MySQL, Calculez la taille de rule_value : 🎜rrreee🎜Vous pouvez voir que la longueur de rule_value est de 74 : 🎜🎜Comment MySQL détermine-t-il la taille de VARCHAR🎜🎜Parce que la valeur de rule_value est un json tableau, donc le tableau La valeur à l'intérieur peut devenir plus grande. À ce stade, nous devons demander confirmation au produit. Quel est le nombre maximum de tableaux à l'intérieur ? 🎜🎜Après enquête, le nombre maximum de tableaux est de 10, alors la longueur calculée de <code>rule_value est : 🎜rrreee🎜C'est-à-dire 740 caractères. Nous pouvons mettre la longueur du rule_value en <code>VARCHAR(255) peut être remplacé par VARCHAR(740). 🎜🎜Enfin, je dois ajouter quelques connaissances : 🎜
  • 🎜TEXT peut enregistrer jusqu'à 65 535 caractères, MEDIUMTEXT peut stocker jusqu'à 16777215 caractères et LONGTEXT peut stocker jusqu'à 4294967295 caractères, mais cela n'est généralement pas recommandé. Utilisez la commande 🎜🎜
  • 🎜View MySQL : select version(); >MySQL
version 4 , calculé en octets, calculé en caractères après la version 4 ; 🎜🎜
  • 🎜LENGTH() Renvoie la longueur de la chaîne en octets. CHAR_LENGTH()Renvoie la longueur de la chaîne en caractères. 🎜🎜🎜
  • Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

    Déclaration:
    Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer