Выбор правильного типа данных в столбце
Для того чтобы память использовалась наиболее эффективно, всегда следует стараться применять тип данных, обеспечивающий максимальную точность. Например, для величин в диапазоне между 1 и 99999 в целочисленном столбце наилучшим типом будет MEDIUMINT UNSIGNED .
Часто приходится сталкиваться с такой проблемой, как точное представление денежных величин. В MySQL для представления таких величин необходимо использовать тип данных DECIMAL . Поскольку данные этого типа хранятся в виде строки, потерь в точности не происходит. А в случаях, когда точность не имеет слишком большого значения, вполне подойдет и тип данных DOUBLE .
Если же требуется высокая точность, всегда можно выполнить конвертирование в тип данных с фиксированной точкой. Такие данные хранятся в виде BIGINT . Это позволяет выполнять все вычисления с ними как с целыми числами, а впоследствии при необходимости результаты можно преобразовать обратно в величины с плавающей точкой.
Использование типов столбцов из других баз данных
Чтобы облегчить использование SQL-кода, написанного для баз данных других поставщиков, в MySQL установлено соответствие типов столбцов, как показано в следующей таблице. Это соответствие упрощает применение описаний таблиц баз данных других поставщиков в MySQL:
Тип иного поставщика | Тип MySQL | BINARY(NUM) | CHAR(NUM) BINARY | CHAR VARYING(NUM) | VARCHAR(NUM) | FLOAT4 | FLOAT | FLOAT8 | DOUBLE | INT1 | TINYINT | INT2 | SMALLINT | INT3 | MEDIUMINT | INT4 | INT | INT8 | BIGINT | LONG VARBINARY | MEDIUMBLOB | LONG VARCHAR | MEDIUMTEXT | MIDDLEINT | MEDIUMINT | VARBINARY(NUM) | VARCHAR(NUM) BINARY |
Соотнесение типов столбцов происходит во время создания таблицы. При создании таблицы с типами столбцов, которые используются другими поставщиками, после запуска команды DESCRIBE имя_таблицы выдается структура данной таблицы с применением принятых в MySQL эквивалентных типов.
Требования к памяти для различных типов столбцов
Требования к объему памяти для столбцов каждого типа, поддерживаемого MySQL, перечислены ниже по категориям.
Требования к памяти для числовых типов
Тип столбца | Требуемая память | TINYINT | 1 byte | SMALLINT | 2 байта | MEDIUMINT | 3 байта | INT | 4 байта | INTEGER | 4 байта | BIGINT | 8 байтов | FLOAT(X) | 4, если X <= 24 или 8, если 25 <= X <= 53 | FLOAT | 4 байта | DOUBLE | 8 байтов | DOUBLE PRECISION | 8 байтов | REAL | 8 байтов | DECIMAL(M,D) | M+2 байт, если D > 0, M+1 байт, если D = 0 (D +2, если M < D ) | NUMERIC(M,D) | M+2 байт, если D > 0, M+1 байт, если D = 0 (D +2, если M < D ) |
Требования к памяти для типов даты и времени
Тип столбца | Требуемая память | DATE | 3 байта | DATETIME | 8 байтов | TIMESTAMP | 4 байта | TIME | 3 байта | YEAR | 1 байт |
Требования к памяти для символьных типов
Тип столбца | Требуемая память | CHAR(M) | M байт, 1 <= M <= 255 | VARCHAR(M) | L +1 байт, где L <= M и 1 <= M <= 255 | TINYBLOB , TINYTEXT | L +1 байт, где L < 2^8 | BLOB , TEXT | L +2 байт, где L < 2^16 | MEDIUMBLOB , MEDIUMTEXT | L +3 байт, где L < 2^24 | LONGBLOB , LONGTEXT | L +4 байт, где L < 2^32 | ENUM('value1','value2',...) | 1 или 2 байт, в зависимости от количества перечисляемых величин (максимум 65535) | SET('value1','value2',...) | 1, 2, 3, 4 или 8 байт, в зависимости от количества элементов множества (максимум 64) |
VARCHAR , BLOB и TEXT являются типами данных с переменной длиной строки,для таких типов требования к памяти в общем случае определяются реальным размером величин в столбце (представлен символом L в приведенной выше таблице), а не максимально возможным для данного типа размером. Например, столбец VARCHAR(10) может содержать строку с максимальной длиной 10 символов. Реально требуемый объем памяти равен длине строки (L ) плюс 1 байт для записи длины строки. Для строки 'abcd' L равно 4 и требуемый объем памяти равен 5 байтов.
В случае типов данных BLOB и TEXT требуется 1, 2, 3 или 4 байта для записи длины значения данного столбца в зависимости от максимально возможной длины для данного типа. См. раздел Типы данных BLOB и TEXT .
Если таблица включает в себя столбец какого-либо типа с переменной длиной строки, то формат записи также будет переменной длины. Следует учитывать, что при создании таблицы MySQL может при определенных условиях преобразовать тип столбца с переменной длиной в тип с постоянной длиной строки или наоборот. См. раздел Молчаливые изменения определений столбцов.
Размер объекта ENUM определяется количеством различных перечисляемых величин. Один байт используется для перечисления до 255 возможных величин. Используя два байта, можно перечислить до 65535 величин. См. раздел Тип перечисления ENUM .
Размер объекта SET определяется количеством различных элементов множества. Если это количество равно N , то размер объекта вычисляется по формуле (N+7)/8 и полученное число округляется до 1 , 2 , 3 , 4 или 8 байтов. Множество SET может иметь максимум 64 элемента. См. раздел Тип множества SET . 1 2 3 4 5
8 8 8
| |