Hallo,
Mit
$stmt->bind_param("sss", $userMail, $pw, $ak);
lege ich fest, ob die eingefügten Werte ein String oder integer ist. Wenn ich$ak = 1;
schreibe, bin ich davon ausgegangen dass der Wert ein "integer" also$stmt->bind_param("ssi", $userMail, $pw, $ak);
ist
du verwechselst hier zwei Welten. Mit bind_param() teilst du der Datenbank mit, welche(n) Datentyp(en) du als Ergebnis haben möchtest. Die DB versucht dann nach besten Kräften, diesem Wunsch nachzukommen. Welchen Typ die PHP-Variablen vorher haben, die dann die Ergebnisse übernehmen sollen, spielt aber gar keine Rolle, denn PHP ändert die Typen von Variablen kontextabhängig. Ob $ak also vor dem Aufruf von bind_params() ein Integer, ein String, ein Boolean oder gar komplett undefiniert ist, spielt keine Rolle. Du teilst der DB mit, dass du einen String haben möchtest, also bekommst du einen String. Du wünschst dir einen Integer, also bekommst du einen Integer, wenn der Wert in der DB als solcher interpretiert werden kann.
das Script hat die Abfrage nicht ausgeführt
Doch, ganz bestimmt. Nur hast du dann vielleicht nicht das bekommen, was du erwartest.
ändere ich diesen Wert in ein „s“ funktioniert die Abfrage warum?
Der Datentyp "String" kann alles enthalten und unterliegt keinen Regeln oder Beschränkungen. Wenn du einen String bestellst, bekommst du also immer ein gültiges Ergebnis. Wenn du einen anderen Datentyp anforderst, etwa Integer, könnte eine Konvertierung nötig sein, wenn der Datentyp in der DB ein anderer ist, und die Konvertierung kann fehlschlagen. Das Ergebnis ist dann eventuell 0.
So long,
Martin
Success should be measured not so much by the position that one has reached in life,
but by the obstacles one has overcome while trying to succeed.
Selfcode: fo:) ch:{ rl:| br:< n4:( ie:| mo:| va:) de:] zu:) fl:{ ss:) ls:µ js:(