MySQL 5.0. Библиотека программиста | страница 45
ALTER TABLE <Имя таблицы>
ORDER BY <Имя столбца 1> [ASC или DESC],
[<Имя столбца 2> [ASC или DESC],…];Упорядочение строк позволяет ускорить последующие операции сортировки по значениям указанных столбцов. Однако порядок строк в таблице может нарушиться после операций добавления и удаления строк. По умолчанию строки таблицы упорядочиваются по возрастанию значений. Вы можете выбрать направление сортировки, указав ключевое слово ASC (по возрастанию) или DESC (по убыванию).
Для таблиц с типом InnoDB, в которых есть первичный ключ или уникальный индекс, не допускающий неопределенных значений (NOT NULL UNIQUE), эта команда игнорируется, поскольку строки таких таблиц автоматически упорядочиваются по значениям этого ключа/индекса.
• Задать опциональные свойства таблицы (см. пункт «Опциональные свойства таблицы») вы можете с помощью командыALTER TABLE <Имя таблицы> <Опциональное свойство таблицы>;
Например, изменить тип таблицы можно с помощью команды
ALTER TABLE <Имя таблицы> ENGINE <Новый тип таблицы>;
• Изменить кодировку и правило сравнения символьных значений, используемых по умолчанию для новых символьных столбцов таблицы, можно, как любое другое опциональное свойство таблицы, с помощью команды
ALTER TABLE <Имя таблицы>
CHARACTER SET <Имя кодировки>
[COLLATE <Имя правила сравнения>];Например, если для таблицы Products (Товары) требуется установить в качестве кодировки по умолчанию кодировку CP-1251, это можно сделать с помощью команды
ALTER TABLE Products CHARACTER SET cp1251;
После выполнения этой команды существующие столбцы таблицы Products по-прежнему будут иметь кодировку UTF-8. Если же с помощью команды ALTER TABLE будут добавляться новые символьные столбцы, то им будет по умолчанию присваиваться кодировка CP-1251. Если вы хотите не только изменить кодировку, используемую по умолчанию для новых столбцов, но и преобразовать в новую кодировку существующие символьные столбцы таблицы, то нужно использовать команду
ALTER TABLE <Имя таблицы>
CONVERT TO CHARACTER SET <Имя кодировки>
[COLLATE <Имя правила сравнения>];При выполнении этой команды не просто меняются описания символьных столбцов: данные в этих столбцах также преобразуются в новую кодировку. Например, после выполнения команды
ALTER TABLE Products CONVERT TO CHARACTER SET cp1251;
все наименования и описания товаров (значения столбцов description и details) преобразуются в кодировку CP-1251. Если же данные в столбце фактически закодированы с помощью одной кодировки, а в описании столбца указана другая кодировка, исправить эту ошибку можно, изменив кодировку