|
|
|
last_insert_id()
|
|||
|---|---|---|---|
|
#18+
Добрый день! Чей автоинкремент вернет select last_insert_id() при insert-е в табличку, на которой висит триггер на insert в другую таблицу? Я, конечно, проверил: - возвращает last из первой. Нету ли тут какой-нибудь засады? И куда девается в таком случае last_insert_id() из второй таблицы? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.11.2014, 21:35:33 |
|
||
|
last_insert_id()
|
|||
|---|---|---|---|
|
#18+
miv32, засада может быть в типе триггера. Если он висит на BEFORE INSERT, тогда вполне логично, что он возвращает ID из первой (изменяемой руками) таблицы. Если же он на AFTER INSERT, тогда по идее он должен возвращать ID из второй (изменяемой триггером) таблицы. Сам не проверял, просто исхожу из общих соображений :) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.11.2014, 23:00:10 |
|
||
|
last_insert_id()
|
|||
|---|---|---|---|
|
#18+
Проверил на afte insert - возвращает last из первой таблицы ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.11.2014, 23:14:26 |
|
||
|
last_insert_id()
|
|||
|---|---|---|---|
|
#18+
Алекс М.miv32, засада может быть в типе триггера. Если он висит на BEFORE INSERT, тогда вполне логично, что он возвращает ID из первой (изменяемой руками) таблицы. Если же он на AFTER INSERT, тогда по идее он должен возвращать ID из второй (изменяемой триггером) таблицы. Сам не проверял, просто исхожу из общих соображений :) не верная логика. в мускле на этапе тригера бифо, ещо нету автоинкрементного поля!!! функция ласт_инсерт_айди возвращает последний сгенерированый аутоинкремент! тоесть указывая явно айдишник - мы не изменим это значение. ласт_инсерт_айди уже доступна на этапе тригеров афтер - всмысле что будет возвращать айди имено токо что вставленой записи, и будет его возвращать пока не произойдёт ещо одна вставка, всеравно каким боком, пусть там хоть будет цепное вызывание тригеров 10 штук... всегда возвращаеться айди вставленного последним на момент вызова. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 12.11.2014, 00:22:07 |
|
||
|
|

start [/forum/topic.php?fid=47&msg=38802814&tid=1833951]: |
0ms |
get settings: |
9ms |
get forum list: |
17ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
48ms |
get topic data: |
8ms |
get forum data: |
2ms |
get page messages: |
46ms |
get tp. blocked users: |
2ms |
| others: | 243ms |
| total: | 381ms |

| 0 / 0 |
