Heim >Backend-Entwicklung >PHP-Tutorial >Problem mit dem Phalcon-Datenbankmodul
Das Unternehmen hat nicht die von phalcon bereitgestellte Klassenbibliothek zum Betrieb der Datenbank verwendet, sondern PhalconDbAdapterPdoMysql, um sie erneut zu kapseln. Ich habe jedoch festgestellt, dass viele Methoden darin Probleme haben.
Zum Beispiel
$statement = $db->prepare('SELECT * FROM robots WHERE name = :name');
$result = $connection->executePrepared($statement, array('name' => 'Voltron'));
Dieser Code läuft nicht reibungslos und meldet immer einen Fehler mit falschem Wert
Und das
$resultset = $connection->query("SELECT * FROM robots WHERE type='mechanical'");
$resultset = $connection->query("SELECT * FROM robots WHERE type='mechanical'"); robots WHERE type=?", array("mechanical"));
Was zurückgegeben wird, ist kein Array, aber es gibt keine Erklärung dafür, dass die Ergebnismenge des Arrays abgerufen werden kann wieder mit der Erklärungsmethode
Wie auch immer, warte einfach. . . Die oben genannten Beispiele stammen alle aus offiziellen Dokumenten
Das Unternehmen hat nicht die von phalcon bereitgestellte Klassenbibliothek zum Betrieb der Datenbank verwendet, sondern PhalconDbAdapterPdoMysql, um sie erneut zu kapseln. Ich habe jedoch festgestellt, dass viele Methoden darin Probleme haben.
Zum Beispiel
$statement = $db->prepare('SELECT * FROM robots WHERE name = :name');
$result = $connection->executePrepared($statement, array('name' => 'Voltron'));
Dieser Code läuft nicht reibungslos und meldet immer einen Fehler mit falschem Wert
Und das
$resultset = $connection->query("SELECT * FROM robots WHERE type='mechanical'");
$resultset = $connection->query("SELECT * FROM robots WHERE type='mechanical'"); robots WHERE type=?", array("mechanical"));
Was zurückgegeben wird, ist kein Array, aber es gibt keine Erklärung dafür, dass die Ergebnismenge des Arrays abgerufen werden kann wieder mit der Erklärungsmethode
Wie auch immer, warte einfach. . . Die oben genannten Beispiele stammen alle aus offiziellen Dokumenten
Zunächst einmal sollte der Platzhalter der Methode „executePrepared“ numerisch sein. Wie zum Beispiel das Englisch im roten Feld des Dokuments:
Das heißt, der Parameterbindungsplatzhalter in Ihrer SQL sollte wie folgt durch „?“ ersetzt werden:
<code class="php"> $statement=$db->prepare('SELECT * FROM robots WHERE name = ?'); $result=$connection->executePrepared($statement, array('Voltron'));</code>
Zweitens gibt die Abfragemethode selbst eine Objektinstanz zurück. Dies wird im Dokument erläutert und es wird auch erläutert, wie ein Array zurückgegeben wird:
Hier gebe ich Ihnen einen weiteren Beispielcode:
<code class="php"> $result = $connection -> query($sql); $result -> setFetchMode(Db::FETCH_ASSOC); $array = $result -> fetchAll();</code>
Freundliche Erinnerung: Weitere Dokumente lesen:)
Referenzdokument: Linkbeschreibung
Linkbeschreibung