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

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Пересчет id

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Описание: Пересчет id
ЯД
Отправлено: 25 Января, 2008 - 16:49:44
Post Id



Новичок


Покинул форум
Сообщений всего: 34
Дата рег-ции: Янв. 2008  
Откуда: Санкт-Петербург


Помог: 0 раз(а)

[+]


Люди есть какая-нибудь функция для пересчета id. Вот например у меня есть таблица с полем id и полем имя

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

Я удаляю строку id=2 и как мне сделать пересчет id, что-бы все опять шло по порядку 1,2 а не 1,3
 
 Top
EuGen Администратор
Отправлено: 25 Января, 2008 - 18:56:09
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




А зачем Вам это? Если сильно надо, то:
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.  

На практике такое никогда не требуется.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
ЯД
Отправлено: 25 Января, 2008 - 21:08:07
Post Id



Новичок


Покинул форум
Сообщений всего: 34
Дата рег-ции: Янв. 2008  
Откуда: Санкт-Петербург


Помог: 0 раз(а)

[+]


Спасибо. Это мне просто для общего развития.
 
 Top
SION-ZENIT
Отправлено: 25 Января, 2008 - 23:22:12
Post Id


Частый гость


Покинул форум
Сообщений всего: 148
Дата рег-ции: Июль 2007  
Откуда: SPb


Помог: 0 раз(а)




Читал где-то что это не советуется делать! Это поле берется для уникальности, что бы не было повторений, и всегда по этому полю можно выделить только одну запись!!!
 
 Top
EuGen Администратор
Отправлено: 29 Января, 2008 - 09:58:41
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




Как правило, id это всего лишь некое внутреннее значение, однозначно идентифицирующее строку. И при этом совершенно не обязательно, чтобы оно представляло из себя правильную арифметическую прогрессию с разностью 1.
Просто помните, что это первичный ключ, некая последовательность уникальных значений, и этого вполне достаточно.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB