какой тип данных я должен использовать для идентификаторов в базе данных? - PullRequest
0 голосов
/ 11 февраля 2019

Я видел много дискуссий и статей о том, какое целое число (приращение) и uuid следует использовать для идентификаторов в базе данных.

Там были представлены некоторые плюсы и минусы как целого числа, так и uuid.

Например, целое число: быстрое, но доступный размер ограничен (если вы не используете bigint) uuid: очень уникальный и гораздо более безопасный, но медленный и занимающий много памяти

Затем я подумал, не использовать ли случайные строкидлина около 10 (varchar (10)), состоящая из прописных и строчных букв, и целые числа решат проблемы, потому что они не такие большие по размеру и могут охватывать широкий диапазон данных (62 ^ 10 способов, если 10 символов).

Итак, мой вопрос: хорошо или плохо это делать?

1 Ответ

0 голосов
/ 11 февраля 2019

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

Вы упомянули некоторые плюсы и минусы использования int и uuid, и теперь я рекомендую перечислить ваши потребности, чтобы вы могли выбрать, какую использовать.

Также имейте в виду, что вы можете использовать некоторые приемы, чтобы обойти ограничения как int, так и uuids.

Например, если uuid кажется вам подходящим вариантом, но скорость поиска их в базе данных беспокоитвы, то вы можете просто использовать индексацию, чтобы максимизировать скорость для uuids.и если у вас много записей, и вам нужно, чтобы они были быстрыми, вы можете использовать предварительно созданные uuids.(генерируйте некоторые uuids, индексируйте их и выбирайте один из них каждый раз, когда вам нужно)

А для целых можно просто использовать 2 целых в качестве идентификатора, которые оба они вместе сделают идентификатор или некоторые другие.другой математический алгоритм, который делает его немного более безопасным, но все же достаточно быстрым.

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

И для случая, когда в дизайне базы данных можно использовать как целые, так и uuids: совершенно нормально, если это лучший способ сделать это как для удовлетворения ваших потребностей, так и для достижения максимальной производительности изэто.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...