Как можно проставить порядковые номера в колонке гарантированно без разрывов?

AUTO INCREMENT вставляет с разрывами. Строки добавляться больше не будут, надо лишь к старым данным применить

19 ответов

18 просмотров

И это не нужно (см. выше)

Kirill- Автор вопроса
Ilya Zviagin
И это не нужно (см. выше)

Мне нужно) Айдишники применить к строкам

Kirill
Мне нужно) Айдишники применить к строкам

ID шники у строк МЕНЯТЬ НИКОГДА НЕЛЬЗЯ!

Kirill- Автор вопроса
Ilya Zviagin
ID шники у строк МЕНЯТЬ НИКОГДА НЕЛЬЗЯ!

Мне нужно первый раз их проставить) Больше они меняться не будут

Во-первых AUTO INCREMENT работает четко, нарасчивая номер на единицу при каждом INSERT обращении. Другое дело, что либо INSERT построины с ignore или on duplicate key update либо строки удаляются, но дело точно не в uto increment. Ищите ошибку в логике в другой стороне

Нет, не обязан

Kirill- Автор вопроса
Ilya Zviagin
Пусть стоят как стоят

Мне-то нужно без разрывов. Это в моем случае важно. Дополняться эта база не будет, лишь по ключам к ID будут обращения из других таблиц

Kirill
Мне-то нужно без разрывов. Это в моем случае важно...

Тебе не может быть это важно. Ну ок, давай покажи DDL таблицы, посмотрим , может правда что не так...

Kirill
Мне-то нужно без разрывов. Это в моем случае важно...

Тогда удаляй auto increment и вешай петлю заранее. Если вдруг все ляпнется, тогда ты уже готов)

Victor Tsiukh
Что не обязан?

AUTO INCREMENT работать четко, наращивая номер на единицу

Kirill- Автор вопроса

В этой таблице как раз строковые уникальные идентификаторы, их нужно применять к объектам, чтобы потом к объектам обращаться по строковому ID. Нужна связь числовых ID. Поэтому разрывов быть не должно

SET @@auto_increment_increment=10; если явно задать, то может увеличивать не на 1, а на 10, я это имела ввиду

Kirill
В этой таблице как раз строковые уникальные иденти...

почиатй про innodb_autoinc_lock_mode и учти что rollback все равно будет вызывать разрыв

Kirill- Автор вопроса
Viktor 🇨🇾
почиатй про innodb_autoinc_lock_mode и учти что ro...

Я читал, представляю. Мне нужно только единожды проставить. Через ЯП можно, но хотелось бы запросиком в MySQL

Похожие вопросы

Обсуждают сегодня

Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
2
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
Andrii Kurdiumov
2
у кого сколько оперативы на базе данных ?
АДИЛЬБЕК
4
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
5
Через бот апи возможно получить ID стикерпака? Не ссылку.
Vexylon [АФК до 09.09]
5
Привет Хочу сделать аналог iCloud’а для своих проектов, чтобы пользовательская информация хранилась в облаке, была доступна во всех сервисах, её можно было подсасывать везде)...
Виталий
9
В тг можно спарсить всех кто пишет в группе? Если список участников скрыт
S
3
код Event::listen('cms.page.display', function (&$content, $slug, $page, $html) { if (is_object($content)) { dump($content); } else { dump($s...
Point 111
3
Доброе утро, мультиязычные сайты делал кто-нибудь? Какие подводные камни? Нужно чего нибудь допом ставить? Как поступить? В теории сделать две папки ru en и туда кидать страни...
Racoon Mitya
2
Карта сайта