Heim > Backend-Entwicklung > PHP-Tutorial > Problem mit dem Phalcon-Datenbankmodul

Problem mit dem Phalcon-Datenbankmodul

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2016-08-04 09:19:49
Original
1277 Leute haben es durchsucht

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

Antwortinhalt:

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:

Problem mit dem Phalcon-Datenbankmodul

Das heißt, der Parameterbindungsplatzhalter in Ihrer SQL sollte wie folgt durch „?“ ersetzt werden:

    $statement=$db->prepare('SELECT * FROM robots WHERE name = ?');
    $result=$connection->executePrepared($statement, array('Voltron'));
Nach dem Login kopieren

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:

Problem mit dem Phalcon-Datenbankmodul

Hier gebe ich Ihnen einen weiteren Beispielcode:

        $result = $connection -> query($sql);
        $result -> setFetchMode(Db::FETCH_ASSOC);
        $array = $result -> fetchAll();
Nach dem Login kopieren

Freundliche Erinnerung: Weitere Dokumente lesen:)

Referenzdokument: Linkbeschreibung
Linkbeschreibung

Verwandte Etiketten:
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Aktuelle Ausgaben
PHP-Datenerfassung?
Aus 1970-01-01 08:00:00
0
0
0
PHP-Erweiterung intl
Aus 1970-01-01 08:00:00
0
0
0
Wie man PHP gut lernt
Aus 1970-01-01 08:00:00
0
0
0
Mehrere PHP-Versionen
Aus 1970-01-01 08:00:00
0
0
0
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage