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

как узнать id

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





СообщениеДобавлено: Чт Авг 26 2004 02:29    Заголовок сообщения: как узнать id Ответить с цитатой

Вопрос касается MySQL.
Есть таблица с автоинкрементом столбца "id", я делаю запись в эту таблицу. Подскажите плиз, как мне узнать под каким id эта запись сохранилась?
Всем спасибо!
Вернуться к началу
яф
Гость





СообщениеДобавлено: Пт Сен 03 2004 11:19    Заголовок сообщения: Ответить с цитатой

insert into t1 values(турым пурым);
select id from t1 where турым пурым = турым пурым
Вернуться к началу
Scaramouch



Зарегистрирован: 11.01.2004
Сообщения: 143
Откуда: Столица нашей Родины

СообщениеДобавлено: Пт Сен 03 2004 13:53    Заголовок сообщения: Ответить с цитатой

яф писал(а):
insert into t1 values(турым пурым);
select id from t1 where турым пурым = турым пурым


ЭТО НЕВЕРНО!
Точнее сказать верно только если турым пурым - KEY, что, скорее всего, не так.

Если в пыхе, то есть функция mysql_insert_id()
Только учти, что она возвращает int, то есть не стоит использовать например BIGINT в качестве id

Или же просто SELECT LAST_INSERT_ID()
_________________
Ноги - это две лишние руки.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Andy-C



Зарегистрирован: 09.12.2003
Сообщения: 73
Откуда: Нальчик

СообщениеДобавлено: Пт Сен 03 2004 17:29    Заголовок сообщения: Ответить с цитатой

Завести транзакцию с уровнем изоляции: повторяемое чтение.
Это когда видно только то, что было до транзакции и свои изменения.
После вставки смотреть max(id).
Должно быть так.
_________________
До onlina Andrew C.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Scaramouch



Зарегистрирован: 11.01.2004
Сообщения: 143
Откуда: Столица нашей Родины

СообщениеДобавлено: Вт Сен 07 2004 09:53    Заголовок сообщения: Re: как узнать id Ответить с цитатой

Andy-C
4kict писал(а):
Вопрос касается MySQL.
Smile
Если, конечно, у товарища не стоит четвертый мускул, в чем я сильно сомневаюсь
_________________
Ноги - это две лишние руки.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
FUKS



Зарегистрирован: 14.04.2002
Сообщения: 148
Откуда: Москва

СообщениеДобавлено: Вт Сен 07 2004 11:59    Заголовок сообщения: Ответить с цитатой

Scaramouch писал(а):
Или же просто SELECT LAST_INSERT_ID()
...
Если, конечно, у товарища не стоит четвертый мускул, в чем я сильно сомневаюсь


SELECT LAST_INSERT_ID() рулит, а какие тут отличия в 4-ом Мускуле?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Scaramouch



Зарегистрирован: 11.01.2004
Сообщения: 143
Откуда: Столица нашей Родины

СообщениеДобавлено: Вт Сен 07 2004 12:45    Заголовок сообщения: Ответить с цитатой

Сорри, про 4-ый мускул - это было для Andy-C
Цитата:
Завести транзакцию с уровнем изоляции: повторяемое чтение.
Это когда видно только то, что было до транзакции и свои изменения.
После вставки смотреть max(id).
Должно быть так.


В третьем нет никаких транзакций
А конечно, что касается LAST_INSERT_ID(), тут никаких отличий нет
_________________
Ноги - это две лишние руки.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
XYNXYZ
Гость





СообщениеДобавлено: Сб Сен 18 2004 13:32    Заголовок сообщения: mysql_insert_id Ответить с цитатой

У меня вопрос по работе этой функции.
В мануале сказано что она "Возвращает ID, сгенерированный при последнем INSERT-запросе" к базе..
А если к базе обращается куча юзеров? Где гарантия что в данный момент времени никто больше не использует insert?
Можно блокировать таблицу предварительно, но это мало что дает.

Кто знает как покорректней решить проблему?
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: 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
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...