В этой статье я поделюсь опытом проектирования идентификаторов для крупной медицинской системы. Мы пройдем путь от простых автоинкрементов до UUID, ULID и в итоге создадим гибридное решение, которое оказалось лучше всех существующих подходов. Спойлер: идеальный ID — это не технология, а архитектура.
Введение: Проклятие выбора
Каждый разработчик сталкивался с дилеммой: что использовать в качестве первичного ключа?
// Вариант 1: Старый добрый автоинкремент
$table->id(); // 1, 2, 3...
// Вариант 2: Модный UUID
$table->uuid('id')->primary(); // 9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d
// Вариант 3: Хайповый ULID
$table->ulid('id')->primary(); // 01HXYZ1234ABC5678DEF90GH
