powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / MySQL [игнор отключен] [закрыт для гостей] / last_insert_id()
5 сообщений из 5, страница 1 из 1
last_insert_id()
    #38802814
miv32
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Добрый день!
Чей автоинкремент вернет select last_insert_id() при insert-е в табличку, на которой висит триггер на insert в другую таблицу?
Я, конечно, проверил: - возвращает last из первой.
Нету ли тут какой-нибудь засады? И куда девается в таком случае last_insert_id() из второй таблицы?
...
Рейтинг: 0 / 0
last_insert_id()
    #38802851
Алекс М.
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
miv32, засада может быть в типе триггера. Если он висит на BEFORE INSERT, тогда вполне логично, что он возвращает ID из первой (изменяемой руками) таблицы. Если же он на AFTER INSERT, тогда по идее он должен возвращать ID из второй (изменяемой триггером) таблицы.
Сам не проверял, просто исхожу из общих соображений :)
...
Рейтинг: 0 / 0
last_insert_id()
    #38802859
miv32
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Проверил на afte insert - возвращает last из первой таблицы
...
Рейтинг: 0 / 0
last_insert_id()
    #38802875
Алекс М.
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
miv32, ну тогда остаётся читать мануаль и искать грабли :)
...
Рейтинг: 0 / 0
last_insert_id()
    #38802886
alex564657498765453
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Алекс М.miv32, засада может быть в типе триггера. Если он висит на BEFORE INSERT, тогда вполне логично, что он возвращает ID из первой (изменяемой руками) таблицы. Если же он на AFTER INSERT, тогда по идее он должен возвращать ID из второй (изменяемой триггером) таблицы.
Сам не проверял, просто исхожу из общих соображений :)

не верная логика. в мускле на этапе тригера бифо, ещо нету автоинкрементного поля!!!

функция ласт_инсерт_айди возвращает последний сгенерированый аутоинкремент! тоесть указывая явно айдишник - мы не изменим это значение.

ласт_инсерт_айди уже доступна на этапе тригеров афтер - всмысле что будет возвращать айди имено токо что вставленой записи, и будет его возвращать пока не произойдёт ещо одна вставка, всеравно каким боком, пусть там хоть будет цепное вызывание тригеров 10 штук...
всегда возвращаеться айди вставленного последним на момент вызова.
...
Рейтинг: 0 / 0
5 сообщений из 5, страница 1 из 1
Форумы / MySQL [игнор отключен] [закрыт для гостей] / last_insert_id()
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]