Порядок байтов MySql UUID

У меня есть таблица MySql, в которой первичным ключом является столбец с автоинкрементом, а также столбец binary(16) с уникальным индексом для хранения UUID.

MySqlConnector имеет вариант подключения для GuidFormat, в котором я запутался между TimeSwapBinary16 и LittleEndianBinary16 с точки зрения того, какой из них был бы лучшим выбором и почему.

Обеспечивает ли расположение байтов UUID в определенном порядке преимущество, когда речь идет об эффективности и производительности, например, во время вставок, индексации, выбора с помощью столбца binary(16) в предложении WHERE и т. д.?

Может кто-нибудь объяснить это?

Пожалуйста, добавьте к своему вопросу, каковы ваши критерии для выбора одного из двух параметров. Один не лучше другого, если только вы не добавите критерий к своему решению. Вопрос в том, "лучший выбор для чего?".

Progman 27.01.2019 14:02
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
3
1
1 447
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Существует общий принцип, заключающийся в том, что вставка новых значений в индекс в порядке возрастания приводит к более эффективному индексу.

Хотя формат UUID по умолчанию для MySQL включает байты, сгенерированные из метки времени, они не находятся в позиции байта в UUID, которая соответствует цели «вставить в порядке возрастания». В MySQL 8.0 они представили функцию UUID_TO_BIN(), которая имеет возможность переупорядочивать байты так, чтобы при генерации значений UUID они упорядочивались по отметке времени.

Опция соединителя TimeSwapBinary16 использует эту опцию, поэтому она лучше подходит для вставки индекса.

Разница в производительности между неупорядоченными и упорядоченными UUID показана с подробными тестами в этом сообщении блога, если вам интересно: https://www.percona.com/blog/2014/12/19/store-uuid-optimized-way/

Другие вопросы по теме