Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Пересчет id
Форумы портала PHP.SU » PHP » SQL и Архитектура БД » Пересчет id

Страниц (1): [1]
 

1. ЯД - 25 Января, 2008 - 16:49:44 - перейти к сообщению
Люди есть какая-нибудь функция для пересчета id. Вот например у меня есть таблица с полем id и полем имя

id | name
1 | bob
2 | ben
3 | mike

Я удаляю строку id=2 и как мне сделать пересчет id, что-бы все опять шло по порядку 1,2 а не 1,3
2. EuGen - 25 Января, 2008 - 18:56:09 - перейти к сообщению
А зачем Вам это? Если сильно надо, то:
PHP:
скопировать код в буфер обмена
  1.  
  2. //id у Вас равно 2
  3. mysql_query("DELETE FROM `your_table` WHERE id=$id"); //удаляем из таблицы
  4. mysql_query("UPDATE `your_table` SET id=id-1 WHERE id>$id");//изменяем id
  5.  

На практике такое никогда не требуется.
3. ЯД - 25 Января, 2008 - 21:08:07 - перейти к сообщению
Спасибо. Это мне просто для общего развития.
4. SION-ZENIT - 25 Января, 2008 - 23:22:12 - перейти к сообщению
Читал где-то что это не советуется делать! Это поле берется для уникальности, что бы не было повторений, и всегда по этому полю можно выделить только одну запись!!!
5. EuGen - 29 Января, 2008 - 09:58:41 - перейти к сообщению
Как правило, id это всего лишь некое внутреннее значение, однозначно идентифицирующее строку. И при этом совершенно не обязательно, чтобы оно представляло из себя правильную арифметическую прогрессию с разностью 1.
Просто помните, что это первичный ключ, некая последовательность уникальных значений, и этого вполне достаточно.

 

Powered by ExBB FM 1.0 RC1