Mysql реиндексация

программирование php MySQL базы данных sql

В базу вываливаются логи по действиям определенных, ну, скажем, пользователей. Иногда они приходят пустые (ошибка не моя, но делать надо :/ ), так вот, есть микрозапрос, где все эти "пустые" строки удаляются, а в итоге id может быть 1,2,4,6,99,1455,1456,1457 и т.п.. как можно переиндексировать? Чтобы вернуть таблице вид 1,2,3,4,5,6,7,8 и так далее?) Подскажите, пожалуйста, кто понял.

Примечание:
Да, bigint может не хватить))

Примечание:
Целостность не нарушится
Ответы:
А зачем? В чем смысл перенумерации записей в таблице? Это же просто, как я понял, автоинкрементное поле, уникальный ключ. Какая разница, в каком порядке и с какими разрывами он идет? Опять же, если на записи в вашу таблицу есть ссылки по id, вам придется перетряхивать все это дело для сохранения ссылочной целостности. Или вы боитесь, что вам не хватит длины BIGINT (или что там у вас в id)?
Простой подсчет говорит, что unsigned bigint(8), при 1000 новых записей в секунду, переполнится через 584542046 лет непрерывной работы. Точно может нехватить?
А так - добавляете новый столбец, заполняете его последовательно, дропаете Primary Key, убиваете старый столбец, переименовываете новый, создаете Primary Key.


11 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.