Im Homepage und Webhosting-Forum --- Anfänger Select von dropdown Problem
Scripte und Programme für PHP, MYSQL. Diskussionen zur Programmierung im Web. Fragen zu CMS, Blogsoftware, Shops, Newsletter und vielen weiteren Scripten.
Hallo liebes Forum,
Da ich niemanden persöhnlich fragen kann poste ich mal meinen code hier:
include 'logindata.php'; # Die Verbindung wird hergestellt bekomme auch das echo OK!
?>
Fehlermeldung:
Warning: mysqli_num_rows() expects parameter 1 to be mysqli_result, boolean given in /home/.sites/41/site1524/web/mysql/abfrage/abfrage.php on line 39
Es wird hier sicherlich an was grundlegendem liegen was ich noch nicht verstanden habe!
Bitte nimm nicht an das ich das recht gut kann ich bin gerade mitten im lernen, habe 2 Bücher vor mir liegen und ein Galileo computing tut offen.
Wie gesagt für kleinere Erklärungen wie zbsp.:
Lass dir die Fehlermeldung ausgeben mit zbsp. ......... weil so macht man das, wäre ich sehr dankbar!
Dankeschön
Zu deinem Problem:
Die Syntax sieht korrekt aus. Aber die Abfrage gibt wohl false zurück, d.h. es ist ein Fehler aufgetreten. Den kannst du dir mit $verbindung->error oder mysqli_error($verbindung) ansehen. Rufe es direkt nach der Abfrage auf und gib es mit echo aus.
Ich finde die Klammern um das Instrument übrigens seltsam - die würde ich gar nicht erst in der Datenbank speichern.
Und ein paar generelle Dinge:
- Den echten Vorteil bringt mysqli, wenn du es objekt-orientiert verwendest. Es ist kürzer und lässt dich neue Methoden für die Datenbankbehandlung direkt in die Klasse schreiben, wo sie hingehören.
- Benutz kein ISO-8859-1, sondern UTF-8. Dann kannst du alle Zeichen benutzen, quasi alle können es verarbeiten und
- HTML 4.01 Transitional ist auch von gestern.
- ist auch doof. (Das Attribut name ist in deinem Fall übrigens überflüssig.) Nimm lieber .
- NIEMALS Parameter DIREKT an MySQL füttern! (oder was passiert beim Aufruf von abfrage.php?instrument='; DROP TABLE musiker; # ? Kleiner Tipp: Nicht ausprobieren.) Stattdessen sollten alle Strings, die nicht sicher sind (also von außen kommen), vorher durch mysqli_real_escape_string gejagt werden, damit sowas nicht passieren kann. Etwa so:
$abfrage = mysqli_query($verbindung, sprintf("SELECT * FROM musiker WHERE instrument = '(%s)'", mysqli_real_escape_string($_GET['instrument'])));
Es gibt noch weitere Möglichkeiten (z.B. Prepared Statements).
Ich habe jetzt folgende Änderungen vorgenommen:
-1. Den Error eingebaut der mir jetzt sagt no database selected
-2. Die Abfrage so geändert wie du es gesagt hast (string)
-3. UTF-8 hab ich auch gemacht
-4. Was sollte ich statt HTML 4.01 Sonst nehmen oder einfach nur noch HTML?
Mein Problem ist:
Ich habe zwei Bücher vor mir und ein galileo tut.
Überall wird es anders gemacht bzw. wird ein formular mit anschliessender auswertung garnicht behandelt
include 'logindata.php'; # Die Verbindung wird hergestellt bekomme auch das echo OK!
?>
Richtig, du musst noch die Datenbank auswählen. Meist benutzt man mit einer Verbindung nur eine einzige Datenbank, wähle sie mit dem vierten Parameter von mysqli_connect() aus:
Vermutlich willst du die Datenbank auch in eine Variable auslagern, die in der Datei logindata.php gespeichert wird. Die solltest du übrigens logindata.inc taufen, damit sie nicht von außen aufgerufen werden kann. Außerdem sollten es keine Variablen sein, da deren Inhalte verändert werden könnten. Stattdessen bieten sich Konstanten an. Sie lassen sich mit define() festlegen und ihre Namen werden komplett in Großbuchstaben geschrieben (nicht notwendigerweise, ist aber Konvention).
Wenn du UTF-8 statt ISO-8859-1 benutzt, musst du vermutlich auch die Einstellungen deines Editors ändern, damit es wirklich UTF-8 ist. Bei den Zeichen, die du im Moment verwendest, sind sie aber gleich.
Im Moment wird an HTML 5 gebrütet, der Doctype sieht dann so aus:
1:
Wenn dir das zu experimentell ist, nimm HTML 4.01 Strict (), XHTML 1.0 Strict oder XHTML 1.1. Deren Doctype kannst du im Zweifelsfall einfach googlen. Auf diese Weise erzeugt Dokumente (also das, was im Browser ankommt) kannst du dann durch den W3C Validator jagen; der sagt dir dann, ob alles in Ordnung ist. Solltest du dich für XHTML entscheiden, achte auf die XML-Präambel und das Schließen von Tags ohne Endtag, wie und .