mysql LAST_INSERT_ID не работает через переполнение стека

Я попробовал два способа достичь этой работы:

multi_query:

$sql = "START TRANSACTION; INSERT INTO songs (title, disco, deleted) VALUES ('".$titol."', '".$codi."', '0'); SET @last_id = LAST_INSERT_ID(); INSERT INTO lyrics (`lyricsOri`, `lyricsTra`, `song`, `deleted`) VALUES ('".$lyricsO."', '".$lyricsT."', @last_id, 0); COMMIT;";

connection()->multi_query($sql);

и транзакция:

    connection()->begin_transaction(MYSQLI_TRANS_START_READ_ONLY);
connection()->query("START TRANSACTION;");
connection()->query("INSERT INTO songs (title, disco, deleted) VALUES ('".$titol."', '".$codi."', '0');");
connection()->query("SET @last_id = LAST_INSERT_ID();");
connection()->query("INSERT INTO lyrics (`lyricsOri`, `lyricsTra`, `song`, `deleted`) VALUES ('".$lyricsO."', '".$lyricsT."', @last_id, 0);");
connection()->query("COMMIT;");
connection()->commit();
connection()->close();

Все записи хорошо записаны, кроме колонки песен в таблице песен, которая занимает НОЛЬ значение.

Кто-нибудь может мне с этим помочь?

Спасибо!

0

Решение

Эти множественные запросы выполняются один за другим, поэтому LAST_NSERT_ID () не применяется ни к чему.

Вы можете использовать сочетание этих двух методов, чтобы достичь того, что вам нужно:

        connection()->begin_transaction(MYSQLI_TRANS_START_READ_ONLY);
connection()->query("START TRANSACTION;");
connection()->multi_query("INSERT INTO songs (title, disco, deleted) VALUES ('".$titol."', '".$codi."', '0');SET @last_id = LAST_INSERT_ID();INSERT INTO lyrics (`lyricsOri`, `lyricsTra`, `song`, `deleted`) VALUES ('".$lyricsO."', '".$lyricsT."', @last_id, 0);");
connection()->query("COMMIT;");
connection()->commit();
connection()->close();

Теперь var объявлен и используется в одном и том же потоке выполнения запросов, поэтому он будет работать нормально.

Ура!

0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]