it-roy-ru.com

Максимальная длина для текста типа MySQL

Я создаю форму для отправки личных сообщений и хочу установить значение maxlength для текстовой области, соответствующее максимальной длине поля text в моей таблице базы данных MySQL. Сколько символов может хранить текстовое поле типа?

Если много, смогу ли я указать длину в текстовом поле базы данных, как при varchar?

378
CyberJunkie

См. Максимальные числа: http://dev.mysql.com/doc/refman/5.0/en/storage-requirements.html

TINYBLOB, TINYTEXT       L + 1 bytes, where L < 2^8    (255 Bytes)
BLOB, TEXT               L + 2 bytes, where L < 2^16   (64 Kilobytes)
MEDIUMBLOB, MEDIUMTEXT   L + 3 bytes, where L < 2^24   (16 Megabytes)
LONGBLOB, LONGTEXT       L + 4 bytes, where L < 2^32   (4 Gigabytes)

L - количество байтов в вашем текстовом поле. Таким образом, максимальное количество символов для текста составляет 216-1 (с использованием однобайтовых символов). Означает 65 535 символов (с использованием однобайтовых символов).

UTF-8/кодирование MultiByte : при использовании кодирования MultiByte каждый символ может занимать более 1 байта пространства. Для UTF-8 потребление пространства составляет от 1 до 4 байтов на символ.

669
fyr

TINYTEXT: 256 байт
ТЕКСТ: 65 535 байт
СРЕДНИЙ ТЕКСТ: 16 777 215 байт
LONGTEXT: 4 294 967 295 байт

114
Cristian Oana
Type       | Approx. Length     | Exact Max. Length Allowed
-----------------------------------------------------------
TINYTEXT   | 256 Bytes          |           255 characters
TEXT       |  64 Kilobytes      |        65,535 characters
MEDIUMTEXT |  16 Megabytes      |    16,777,215 characters
LONGTEXT   |   4 Gigabytes      | 4,294,967,295 characters

Примечание. Если используются многобайтовые символы (например, арабские буквы, где каждый символ занимает 2 байта), столбец "Максимальная допустимая длина" будет иметь различную длину. Например: если вы используете 2-байтовые символы, точная максимальная длина для TINYTEXT будет 127 символов. По сути, это разрешенное число байтов -1.

59
evilReiko

Согласно http://dev.mysql.com/doc/refman/5.0/en/storage-requirements.html , ограничение составляет L + 2 bytes, where L < 2^16 или 64k.

Вам не нужно беспокоиться об ограничении этого, оно автоматически разбивается на куски, которые добавляются по мере роста строки, поэтому она не всегда будет слепо использовать 64 КБ.

18
Blindy

Сколько символов может хранить текстовое поле типа?

Согласно Документация Вы можете использовать максимум 21 844 символов, если кодировка UTF8

Если много, смогу ли я указать длину в поле типа текста в БД, как в случае с varchar?

Вам не нужно указывать длину. Если вам нужно больше символов, используйте типы данных MEDIUMTEXT или LONGTEXT. В случае VARCHAR заданная длина не для требований к хранилищу, а только для способа извлечения данных из базы данных.

8
SCC
TINYTEXT 256 bytes
TEXT 65,535 bytes ~64kb
MEDIUMTEXT 16,777,215 bytes ~16MB
LONGTEXT 4,294,967,295 bytes ~4GB

TINYTEXT - это строковый тип данных, который может хранить до 255 символов.

TEXT - это строковый тип данных, который может хранить до 65,535 символов. TEXT обычно используется для кратких статей.

LONGTEXT - это строковый тип данных с максимальной длиной символов 4,294,967,295. Используйте LONGTEXT, если вам нужно хранить большой текст, такой как глава романа.

7
Sachith

Для версии MySql 8.0.

Требования к хранению числового типа

Data Type       Storage Required
TINYINT         1 byte
SMALLINT        2 bytes
MEDIUMINT       3 bytes
INT, INTEGER    4 bytes
BIGINT          8 bytes
FLOAT(p)        4 bytes if 0 <= p <= 24, 8 bytes if 25 <= p <= 53
FLOAT           4 bytes
DOUBLE, REAL    8 bytes
DECIMAL(M,D), NUMERIC(M,D)  Varies; see following discussion
BIT(M)  approximately (M+7)/8 bytes

Значения для столбцов DECIMAL (и NUMERIC) представлены в двоичном формате, который упаковывает девять десятичных (основание 10) цифр в четыре байта. Хранение для целой и дробной частей каждого значения определяется отдельно. Каждое число, кратное девяти цифрам, требует четырех байтов, а оставшиеся цифры требуют некоторой доли четырех байтов. Объем памяти, необходимый для избыточных цифр, указан в следующей таблице.

Требования к хранилищу типа даты и времени Для столбцов TIME, DATETIME и TIMESTAMP, хранилище, необходимое для таблиц, созданных до MySQL 5.6.4, отличается от таблиц, созданных с 5.6.4 и далее. Это связано с изменением в 5.6.4, которое позволяет этим типам иметь дробную часть, что требует от 0 до 3 байтов.

Data Type   Storage Required Before MySQL 5.6.4   Storage Required as of MySQL 5.6.4
YEAR        1 byte                                1 byte
DATE        3 bytes                               3 bytes
TIME        3 bytes                               3 bytes + fractional seconds storage
DATETIME    8 bytes                               5 bytes + fractional seconds storage
TIMESTAMP   4 bytes                               4 bytes + fractional seconds storage

Начиная с MySQL 5.6.4, хранилище для ГОДА и ДАТЫ остается неизменным. Однако TIME, DATETIME и TIMESTAMP представлены по-разному. DATETIME упаковывается более эффективно, требуя 5, а не 8 байтов для нефракционной части, и все три части имеют дробную часть, которая требует от 0 до 3 байтов, в зависимости от точности сохраненных значений в долях секунды.

Fractional Seconds Precision    Storage Required
0                               0 bytes
1, 2                            1 byte
3, 4                            2 bytes
5, 6                            3 bytes

Например, TIME (0), TIME (2), TIME (4) и TIME (6) используют 3, 4, 5 и 6 байтов соответственно. ВРЕМЯ и ВРЕМЯ (0) эквивалентны и требуют одинакового хранения.

Для получения подробной информации о внутреннем представлении временных значений см. MySQL Internals: Важные алгоритмы и структуры.

Требования к хранению строкового типа В следующей таблице M представляет объявленную длину столбца в символах для недвоичных строковых типов и байтов для двоичных строковых типов. L представляет фактическую длину в байтах данного строкового значения.

Data Type                    Storage Required
CHAR(M)                      The compact family of InnoDB row formats optimize storage for variable-length character sets. See COMPACT Row Format Characteristics. Otherwise, M × w bytes, <= M <= 255, where w is the number of bytes required for the maximum-length character in the character set.
BINARY(M)                    M bytes, 0 <= M <= 255
VARCHAR(M), VARBINARY(M)     L + 1 bytes if column values require 0 − 255 bytes, L + 2 bytes if values may require more than 255 bytes
TINYBLOB, TINYTEXT           L + 1 bytes, where L < 28
BLOB, TEXT                   L + 2 bytes, where L < 216
MEDIUMBLOB, MEDIUMTEXT       L + 3 bytes, where L < 224
LONGBLOB, LONGTEXT           L + 4 bytes, where L < 232
ENUM('value1','value2',...)  1 or 2 bytes, depending on the number of enumeration values (65,535 values maximum)
SET('value1','value2',...)   1, 2, 3, 4, or 8 bytes, depending on the number of set members (64 members maximum)
1
Rohit.007

TEXT - это строковый тип данных, который может хранить до 65 535 символов. Но все же, если вы хотите сохранить больше данных, измените их тип данных на LONGTEXT

ALTER TABLE name_tabel CHANGE text_field LONGTEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL;

1
sohel shaikh