Mysql
 sql >> Datenbank >  >> RDS >> Mysql

SQL gibt einen Syntaxfehler aus, aber ich sehe keinen

PHP Mysqli erlaubt mehrere Abfragen mit der multi_query()-Funktion .

Das Folgende soll die Konversation im Allgemeinen ergänzen und den Kummer durch endloses Out of Sync vermeiden Fehler, wenn Blöcke von mehreren Abfragen übereinander ausgeführt werden. Oder ein Nicht-Multi nach einem Multi.

Der Ärger beginnt nach der Ausführung von multi_query() wenn man dann mit der nächsten Abfrage fortfährt, ohne die Ergebnismenge zu löschen. Der Fehler wäre derjenige, der unten als Note1 bezeichnet wird. Aber es wird in dieser Antwort vermieden.

Ihr spezielles Problem hatte nichts mit \r\n zu tun oder \n\r . Sie wurden als Teil dieser Bemühungen getestet, aber ausgelassen, um die nächste Person, die mit ihrem Problem hereinkommt, nicht zu verwirren, anders.

<?php
    //mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
    mysqli_report(MYSQLI_REPORT_ALL);
    error_reporting(E_ALL); // report all PHP errors
    ini_set("display_errors", 1); 
    echo "start<br/>";

    try {
        $mysqli= new mysqli('hostname', 'dbuser', 'pwd', 'dbname');
        if ($mysqli->connect_error) {
            die('Connect Error (' . $mysqli->connect_errno . ') '
                . $mysqli->connect_error);
        }
        echo "I am connected and feel happy.<br/>";
        $query = "INSERT INTO `table1`(`thing`) values ('aaa')";
        $mysqli->query($query);
        // works fine

        // Note the concat below
        $query = "INSERT INTO `table1`(`thing`) values ('bbb1'); ";
        $query .=$query; // double it up with concat (in other words two insert)
        // we have a multi query so call it the right way:
        $mysqli->multi_query($query);
        // we need to clear the protocol to avoid Out of Sync errors
        // http://stackoverflow.com/a/21754463
        do { 
            $mysqli->use_result(); 
        }while( $mysqli->more_results() && $mysqli->next_result() );        
        // if you remark out the above 3 lines, 
        // expect error message depicted in **** Note1 ****

        // purpose of this next block is to show result sets are cleared
        // from prior multi, and we can do another insert
        // thus avoiding error 500 out of sync errors
        $query = "INSERT INTO `table1`(`thing`) values ('ccc')";
        $mysqli->query($query);   // a single insert statement

        // Finally, this shows that running a multi without a multi_query fcn call will bomb
        $query = "INSERT INTO `table1`(`thing`) values ('explosion'); \r\n";
        $query .=$query; // double it up with concat
        $mysqli->query($query);   // make a multi query explode by not calling multi_query (but rather query)
        //  The above line generated an error, error message below (**** Note2 ****)
        $mysqli->close();
    } catch (mysqli_sql_exception $e) { 
        throw $e; 
    }
?>

Datenbankergebnisse:

select * from table1;
+----+-------+
| id | thing |
+----+-------+
|  1 | aaa   |
|  2 | bbb1  |
|  3 | bbb1  |
|  4 | ccc   |
+----+-------+

Die folgenden Fehlermeldungen werden im gezeigten Quellcode erwähnt. Ersteres wird komplett vermieden. Die zweite nicht, und um zu zeigen, dass die Funktion multi_query() , im Gegensatz zu query() , ist erforderlich.

****** Hinweis1 ******

****** Hinweis2 ******