Страница 1 из 1

Уникальный код по таблице

Добавлено: 2019.10.21, 04:44
Ghost_nsk
Товарищи, привет. Интересует такой вопрос, есть таблица в базе, там какие-то данные. У каждой записи таблицы, есть какой-то уникальный параметр, например, code (varchar 10). Как при создании новой записи, автоматически генерить запись c code, который не похож на другие (уникален)?

Re: Уникальный код по таблице

Добавлено: 2019.10.21, 09:23
ElisDN
bin2hex(random_bytes(5)) с проверкой по БД на уникальность.

А если длина не критична, то лучше Ramsey\Uuid::uuid4()->toString().

Re: Уникальный код по таблице

Добавлено: 2019.10.21, 09:52
Ghost_nsk
ElisDN писал(а): 2019.10.21, 09:23 bin2hex(random_bytes(5)) с проверкой по БД на уникальность.

А если длина не критична, то лучше Ramsey\Uuid::uuid4()->toString().
насколько я понимаю, если в rules добавить unique валидатор, он просто не пропустит модель при сохранении, если будет дубликат по ключу? или я неправильно понимаю?

Re: Уникальный код по таблице

Добавлено: 2019.10.21, 09:54
ElisDN
Да, форма не сохранится и придётся отправлять снова.

Re: Уникальный код по таблице

Добавлено: 2019.10.21, 10:02
Ghost_nsk
ElisDN писал(а): 2019.10.21, 09:54 Да, форма не сохранится и придётся отправлять снова.
это я понимаю, но мне нужно, чтобы форма сохранилась 100%, то есть если код уже есть в базе, видимо как-то в цикле проверять надо, пока не будет найден код, которого в базе нет. Насколько это костыльно?

Re: Уникальный код по таблице

Добавлено: 2019.10.21, 11:13
ElisDN
Про это и говорю, что в случае своих коротких кодов генерировать нужно сразу с проверкой уникальности:

Код: Выделить всё

do {
    $code = bin2hex(random_bytes(5));
} while (Entity::find()->andWhere(['code' => $code])->exists())
А если использовать длинный UUID, то проверка не нужна.

Re: Уникальный код по таблице

Добавлено: 2019.10.21, 11:20
Ghost_nsk
ElisDN писал(а): 2019.10.21, 11:13 Про это и говорю, что в случае своих коротких кодов генерировать нужно сразу с проверкой уникальности:

Код: Выделить всё

do {
    $code = bin2hex(random_bytes(5));
} while (Entity::find()->andWhere(['code' => $code])->exists())
А если использовать длинный UUID, то проверка не нужна.
примерно так и думал, спасибо