Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Как узнать ID (auto_increment) будущей записи в MySQL

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
Рел
Гость





СообщениеДобавлено: Сб Ноя 23 2002 11:45    Заголовок сообщения: Как узнать ID (auto_increment) будущей записи в MySQL Ответить с цитатой

есть:
table "Companies"
---------------------------
id int not null auto_increment,
name tinytext not null,
primary key(id)
---------------------------
как узнать id будущей записи перед её добавлением?
Вернуться к началу
Борис
Гость





СообщениеДобавлено: Пн Ноя 25 2002 16:44    Заголовок сообщения: select max(id) from Companies; однако, или, если хочешь, (id+1). Лично я автоинкремент не уважаю. (-) Ответить с цитатой

-
Вернуться к началу
Рел
Гость





СообщениеДобавлено: Вт Ноя 26 2002 00:10    Заголовок сообщения: Re: select max(id) from Companies; однако, или, если хочешь, (id+1). Лично я автоинкремент не уважаю. (-) Ответить с цитатой

уважаешь случайные числа (комбинации цифр и букв)?
и сколько символов у тебя в идентификаторе ?
5 или 10?
и всё равно вопрос, не разрешён - мне до добавления новой записи нужно узнать её идентификатор, чтобы потом повторно к этой же таблице не обращаться со сложным запросом лишь для того, чтобы вычислить идентификатор %(

вобщем, придётся делать старым макаром...
Вернуться к началу
Борис
Гость





СообщениеДобавлено: Вт Ноя 26 2002 09:35    Заголовок сообщения: Re: select max(id) from Companies; однако, или, если хочешь, (id+1). Лично я автоинкремент не уважаю. (-) Ответить с цитатой

Насколько я знаю, MySQL просто вычисляет max()+1, то есть, если добавлена запись с ID==100, затем она удалена, но новые еще не добавлялись, то добавляемая после этого запись будет иметь снова ID==100. По поводу автоинкремента, то я предпочитаю инкремент, но без "авто-". Я не уважаю автоинкремент, потому что в известных мне реализациях он не гарантирует уникальности (как в приведенном примере, хотя есть и другие примеры).
Вернуться к началу
SemenovV
Гость





СообщениеДобавлено: Вт Ноя 26 2002 16:29    Заголовок сообщения: Re: Как узнать ID (auto_increment) будущей записи в MySQL Ответить с цитатой

а если одновременно много юзеров добавляют
записи в таблицу
видимо надежнее это делать после
добавления
Вернуться к началу
Рел
Гость





СообщениеДобавлено: Ср Ноя 27 2002 06:14    Заголовок сообщения: Re: Как узнать ID (auto_increment) будущей записи в MySQL Ответить с цитатой

ситуация "много юзеров" исключена!
Вернуться к началу
Олигарх



Зарегистрирован: 28.09.2002
Сообщения: 102

СообщениеДобавлено: Пн Дек 02 2002 16:08    Заголовок сообщения: Re: Ответить с цитатой

Если до этого были записи в таблицу, то можно так:

select (LAST_INSERT_ID()+1) as new_id ...

Хотя лучше использовать LAST_INSERT_ID() после записи...
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Рел
Гость





СообщениеДобавлено: Вт Дек 03 2002 00:06    Заголовок сообщения: Re: Ответить с цитатой

Спасибо!

Воспользуюсь! =)
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...