mysql LAST_INSERT_ID не работает через php

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

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();

Все записи записаны хорошо, кроме столбца песни в таблице текстов песен, который принимает значение NULL.

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

Спасибо!


person jDoe    schedule 10.07.2018    source источник
comment
Добро пожаловать в Stack Overflow! Вы не показали определение своей таблицы (таблиц), без которой трудно дать хороший ответ. См. Почему я должен предоставлять MCVE для того, что мне кажется очень простым SQL-запросом?   -  person Toby Speight    schedule 10.07.2018


Ответы (1)


Эти несколько запросов выполняются один за другим после каждого, поэтому 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();

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

Ваше здоровье!

person JoelBonetR    schedule 10.07.2018
comment
@jDoe, если это сработало, примите этот ответ, чтобы закрыть свой вопрос. - person IncredibleHat; 10.07.2018
comment
извините, ТАК не позволяет мне это сделать, так как прошло какое-то время, только что сделал это! - person jDoe; 10.07.2018