Rolf B: Wie initiiert PHP mysqli_stmt_prepare ?

Beitrag lesen

Hallo Leo,

Wird mysqli_stmt_prepare in der if Schleife Anweisung auch gleich initiiert, während diese überprüft, ob eben eine $username und $email Übereinstimmung in der Datenbank gefunden wurde?

Eine Initialisierung erfolgt vorher, in mysqli_stmt_init(). Diese Funktion setzt mögliche Fehlerzustände zurück und erzeugt ein neues, leeres Statement-Objekt.

Die prepare-Funktion bekommt das Objekt und ein SQL Statement. Sie ruft den SQL Server auf und sagt ihm: „Ey guck mal, ich hab da ein Schtäitment, fängst Du damit was an?“ Der Server schaut drauf, prüft, ob das Statement auch SQL ist oder irgendein Phantasiedurcheinander, und meldet dem Aufrufer ein wohlwollendes TRUE oder ein strafendes FALSE zurück. Derweil der Aufrufer damit weitermacht, überlegt er sich auch, wie er wohl dieses SQL am besten in Leseoperationen auf seinen Tabellen umsetzt. Mehr aber auch nicht.

Wenn Du das Ergebnis einer Funktion prüfen willst, dann ist es wenig sinnvoll, sie in der Prüfung nochmal hinzuschreiben. Damit rufst Du sie zweimal auf. Das ist übrigens in jeder Programmiersprache, die ich kenne so. Wenn Du den Aufruf der Funktion nicht in der if-Anweisung drin stehen haben willst, musst Du ihren Rückgabewert in einer Variablen speichern.

Nachdem prepare zurück ist und TRUE gemeldet hat, macht der Aufrufer den bind(), um bekannt zu geben, die Inhalte welcher Variablen für die Fragezeichen einzusetzen sind. Damit das auch nicht zu einfach wird, muss man Fragezeichen abzählen und dem richtigen ? das richtige $ zuordnen. Und auch noch erklären, ob man das als Integer, Double, String oder Blob tun will. Oder man nimmt PDO, da kann man statt ??? ordentliche Namen verwenden. Der Bind erfolgt aber rein in PHP, dafür geht's nicht zum Server.

Erst dann erfolgt der execute, in dem das gebundene Datenpaket an den Server geschickt wird. „Hey Server, ich hab Dir doch eben ein Schtäitment geschickt. Hier sind Daten, stopf sie rein und führ's aus!“. Damit rennt der Server nun los, liest Datentabellen und erzeugt Ergebnisse.

Rolf

--
sumpsi - posui - obstruxi