Требования по обработке данных
При выборе типа данных необходимо принимать во внимание требования к обработке данных разрабатываемого приложения, т.к. данные одних типов лучше подходят для обработки, чем другие. Например, если вы собрались просуммировать все значения по определенному столбцу, совершенно естественно выбрать для этого столбца тип INT.
При работе с датами и временем этот фактор становится еще более критическим, т.к. сравнение даты и времени и операции сравнения дат и временных показателей достаточно сложны, и совершенно естественно воспользоваться всеми возможностями встроенных функций MySQL для выполнения таких операций. С точки зрения производительности будет неразумно хранить даты в виде строк, а потом вручную программировать на прикладном уровне программу сложения, вычитания и сравнения этих величин, когда можно воспользоваться встроенными типами, поддерживающими этот вид операций.
Требования к сортировке, индексированию и операциям сравнения
Планируя начать сортировать все значения столбца по различным критериям, необходимо выбрать тот тип, который способствует самому эффективному выполнению этих функций с сохранением максимальной гибкости. Например, цифровые значения, которые сохраняются в виде символических данных, будут отсортированы совсем не так, как эти же значения, отсортированные как числа. И значения календарных дат, сохраненные в виде текстовых полей, не будут отсортированы так же, как идентичные данные, сохраненные в виде дат. Поэтому очень важно обязательно разобраться, будет ли выбранный тип соответствовать требованиям к сортировке еще до начала этого процесса.
Требования по индексированию также влияют на принятие решения о выборе типа данных. Обычно индексируются поля, которые используются в качестве критерия выборки в запросах, поэтому для повышения скорости обработки, следует создавать индекс с использованием именно таких полей. Правда, несколько неэффективно индексировать по символическим данным по сравнению с числовыми данными, т.к. операции на числовых данных производятся быстрее, чем на строках. Кроме того, более старые версии MySQL накладывают специальные требования относительно полей, объявленных как индексы. Необходимо убедиться в том, что значения полей никак не конфликтуют с этими требованиями.
Аналогично, если вы собираетесь сравнивать различные значения, необходимо убедиться в том, что задействованные в операциях сравнения типы данных, поддерживают сравнение и совместимы друг с другом. Тип сравнения также влияет на используемый тип данных: сравнивая строковые данные, например, необходимо убедиться в том, что это сравнение будет выполнено в двоичном (с учетом регистра) или недвоичном (без учета регистра) стиле и указать соответствующие модификаторы типов в объявлениях столбцов MySQL.
Резюме
Этой главой открывается более детальное обсуждение набора команд MySQL. MySQL снабжен широким диапазоном типов данных, разработанных для поддержки решения практически всех прикладных задач. И предыдущий материал однозначно подтверждает это. Краткие разделы объясняют необходимость присвоения данным определенных типов и объясняют различные критерии при выборе типа данных для столбцов в таблицах MySQL.
ТОП-10 популярных
Для работы с вещественными числами в MySQL предусмотрено три типа данных - это типы FLOAT, DOUBLE, DECIMAL. Числовой тип FLOAT...
БОЛЬШЕ БОЛЬШИХ LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Больше больших LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
НОУТБУК с блестящим экраном
Eсли выпустившая ноутбук фирма предлагает его в качестве «замены настольному ПК», то это должно подразумевать под собой нечто большее, чем...
Eсли выпустившая ноутбук фирма предлагает его в качестве «замены настольному ПК», то это должно подразумевать под собой нечто большее, чем...
Иди и пиши. TravelMate C100
Планшетный компьютер платформы Tablet PC обязан в первую очередь быть легким, способным достаточно долго работать без подзарядки батарей. Эти требования...
Планшетный компьютер платформы Tablet PC обязан в первую очередь быть легким, способным достаточно долго работать без подзарядки батарей. Эти требования...
Магнито-оптический дисковод DynaMO
Cейчас, когда традиционные флоппи-дисководы на долгие годы замерли в своем развитии, поиск альтернативных носителей продолжается, и ситуация, казалось бы, разрешилась...
Cейчас, когда традиционные флоппи-дисководы на долгие годы замерли в своем развитии, поиск альтернативных носителей продолжается, и ситуация, казалось бы, разрешилась...
Компьютер для гурманов.«Эксимер ДМ»
Российская компания «Эксимер ДМ», известная как производитель настольных компьютеров, рабочих станций, серверов и ноутбуков, выступила техническим спонсором проведения торжеств, посвященных...
Российская компания «Эксимер ДМ», известная как производитель настольных компьютеров, рабочих станций, серверов и ноутбуков, выступила техническим спонсором проведения торжеств, посвященных...
Для длинных строк, т.е. строк длиннее 255 символов, в MySQL предусмотрены типы BLOB (Binary Large Object, большой двоичный объект) и...
В дополнение к календарным типам, предназначенным для хранения даты и времени отдельно, MySQL также поддерживает гибридные типы данных DATETIME и...
Вообще, к изменению настроек сервера прибегают очень редко. В MySQL программа заранее настроена так, чтобы соответствовать самым распространенным и основным...
Все о MySQL. Выбор типа данных. Продолжение.
28-12-2009
<< Предыдущая статья | Следующая статья >> |
Все о MySQL. Выбор типа данных | Все о MySQL. Операторы MySQL |