| PHP Developer Forum Hier habt ihr die Möglichkeit, eure Skriptprobleme mit anderen Anwendern zu diskutieren. Seid so fair und beantwortet auch Fragen von anderen Anwendern. Dieses Forum ist sowohl für ANFÄNGER als auch für PHP-Profis! Post your PHP questions here! |
 |
|

07-10-2010, 11:58
|
|
lucil
Registrierter Benutzer
|
|
Registriert seit: Sep 2010
Beiträge: 12
|
|
Problem beim löschen von Datensätzen
Ich hoffe Ihr könnt mir wieder helfen.
Ich möchte mit den unten aufgeführten Script Datensätzer per Auswahl löschen. Das Anzeigen der Datensätze funktioniert nur das löschen nicht.
Ist hier ein Fehler drin den ich nicht sehe?
PHP-Code:
if($submit) { // Wenn der Submit-Button geklickt wurde ... // die Anzahl der markierten Datensaetze ermitteln $y=count($loeschen); echo "$y Datensätze werden gelöscht.<br><br>"; // Für jeden markierten Datensatz // den delete-Befehl aufrufen. for($x=0;$x<$y;$x++) { mysql_query("delete FROM users where ID='$loeschen[$x]'"); echo "Gelöscht: $loeschen[$x]<br>"; } } // Die vorhandenen Datensätze abrufen $result=mysql_query("select user, ID FROM users"); // Nur wenn Daten gefunden wurden, // wird das Formular angezeigt. if(mysql_num_rows($result)) { ?> Bitte wählen Sie welche Accounts gelöscht werden sollen. <form method="post" action="delet.php"> <table width="300" border="0" cellspacing="0" cellpadding="0"> <? // Daten anzeigen while($row=mysql_fetch_array($result,MYSQL_ASSOC)) { $ID=$row["ID"]; $feld=$row["user"]; ?> <tr> <td width="57"> <table width="100%" border="0"> <tr> <td><img src="../images/Benutzer_loeschen.png" width="24" height="24"> </td> <td><input type="checkbox" name="loeschen[]" value="<? echo $ID ?>"></td> </tr> </table> </td> <td width="243"><? echo $feld ?></td> <td width="243"><? echo $ID?></td> </tr> <? } ?> </table> <br> <input type="submit" name="submit" value="Löschen"> </form> <? } else { echo "Keine Daten gefunden."; } ?> </p>
Liebe Grüße
|

07-10-2010, 12:13
|
wahsaga
 Moderator
|
|
Registriert seit: Sep 2001
Beiträge: 24.486
|
|
Zitat:
Zitat von lucil
Ist hier ein Fehler drin den ich nicht sehe?
|
In deinem Script ist vor allem keinerlei Fehler behandlung drin - du feuerst die Abfragen zwar ab, aber danach ist es dir egal, ob sie geklappt haben oder nicht ...
Werte die Rückgabewerte kritischer Funktionen (bspw. mysql_query) aus, und nutze mysql_error.
__________________
I don't believe in rebirth. Actually, I never did in my whole lives.
|

07-10-2010, 12:14
|
|
asisito
Registrierter Benutzer
|
|
Registriert seit: Sep 2010
Ort: Munich / Germany
Beiträge: 16
|
|
Hallo,
gib doch mal eine konkretere Fehlerbeschreibung. Was funktioniert nicht?
Edit: Zu spät
|

07-10-2010, 12:17
|
|
lucil
Registrierter Benutzer
|
|
Registriert seit: Sep 2010
Beiträge: 12
|
|
Vielen Dank für die schnellen Antworten.
Also ich habe das Gefühl das er nicht in die IF Schleife geht nach absenden des Formulars.
Die Datenfelder werden ja richtig dargestellt mit raidobutton usw.
Nur er zählt nicht wie in der for schleife gemacht und er löscht die angewählten Datensätze nicht.
Geändert von lucil (07-10-2010 um 12:20 Uhr)
Grund: etwas vergessen
|

07-10-2010, 12:20
|
|
Wyveres
Registrierter Benutzer
|
|
Registriert seit: Dec 2006
Ort: Rügen
Beiträge: 763
|
|
register_globals ... einfach mal googlen!
|

07-10-2010, 12:21
|
|
asisito
Registrierter Benutzer
|
|
Registriert seit: Sep 2010
Ort: Munich / Germany
Beiträge: 16
|
|
Gefühl? Debugging mit Karma-Deutung?
Spaß, nochmal: was macht er bzw. nicht? Leere Seite?
Setz doch mal bitte
Code:
error_reporting(E_ALL);
unter den ersten Php open tag. Und dann sag, was da steht.
|

07-10-2010, 12:26
|
|
lucil
Registrierter Benutzer
|
|
Registriert seit: Sep 2010
Beiträge: 12
|
|
Nein zeigt alles an wie es soll. nur das löschen geht nicht und er wirft keine fehler aus
|

07-10-2010, 12:33
|
wahsaga
 Moderator
|
|
Registriert seit: Sep 2001
Beiträge: 24.486
|
|
Zitat:
Zitat von lucil
Also ich habe das Gefühl das er nicht in die IF Schleife geht nach absenden des Formulars.
|
Dann bau dort eine Kontrollausgabe ein, um das zu überprüfen!
Und die anderen Hinweise, hast du die umgesetzt?
Wie sieht das inzwischen aus?
__________________
I don't believe in rebirth. Actually, I never did in my whole lives.
|

07-10-2010, 12:44
|
|
lucil
Registrierter Benutzer
|
|
Registriert seit: Sep 2010
Beiträge: 12
|
|
Hab alles umgesetzt.
Er geht nicht in die IF Schleife bzw kommt gar nicht zu ihr hin.
Er macht nur das Select und stellt die Datensätze mit Radiobutton da. Klicke ich dann auf löschen passiert nichts außer das er das Select ausführt.
globale sind richtig
|

07-10-2010, 12:47
|
|
Quetschi
PHP Expert
|
|
Registriert seit: Dec 2004
Beiträge: 2.759
|
|
Zitat:
Zitat von lucil
Hab alles umgesetzt
|
Dann zeig her...
Zitat:
Zitat von lucil
globale sind richtig
|
Wie meinen?
__________________
Drelingdo
Krabonse
Simmannamando
|

07-10-2010, 12:51
|
|
lucil
Registrierter Benutzer
|
|
Registriert seit: Sep 2010
Beiträge: 12
|
|
Bitte schön :-)
Bis zur Abfrage kommt er. Geht aber nicht rein
PHP-Code:
<? echo "Bin vor der Schleife --->"; if($submit){ echo "Bin in der Schleife---->"; // Wenn der Submit-Button geklickt wurde ... // die Anzahl der markierten Datensaetze ermitteln $y=count($loeschen); echo "$y Datensätze werden gelöscht.<br><br>"; // Für jeden markierten Datensatz // den delete-Befehl aufrufen. for($x=0;$x<$y;$x++) { echo "Bin in der FOR Schleife"; mysql_query("delete FROM users where ID='$loeschen[$x]'"); echo "Gelöscht: $loeschen[$x]<br>"; } } // Die vorhandenen Datensätze abrufen $result=mysql_query("select user, ID FROM users"); // Nur wenn Daten gefunden wurden, // wird das Formular angezeigt. if(mysql_num_rows($result)) { ?> Bitte wählen Sie welche Accounts gelöscht werden sollen. <form method="post" action="delet.php"> <table width="300" border="0" cellspacing="0" cellpadding="0"> <? // Daten anzeigen while($row=mysql_fetch_array($result,MYSQL_ASSOC)) { $ID=$row["ID"]; $feld=$row["user"]; ?> <tr> <td width="57"> <table width="100%" border="0"> <tr> <td><img src="../images/Benutzer_loeschen.png" width="24" height="24"> </td> <td><input type="checkbox" name="loeschen[]" value="<? echo $ID ?>"></td> </tr> </table> </td> <td width="243"><? echo $feld ?></td> <td width="243"><? echo $id ?></td> </tr> <? } ?> </table> <br> <input type="submit" name="submit" value="Datensatz löschen"> </form> <? } else { echo "Keine Daten gefunden."; } ?> </p>
|

07-10-2010, 12:57
|
|
Quetschi
PHP Expert
|
|
Registriert seit: Dec 2004
Beiträge: 2.759
|
|
Ich seh immer noch kein mysql_error() in deinem Code.
EDIT:
Und auch kein aufgedrehtes error_reporting.
__________________
Drelingdo
Krabonse
Simmannamando
|

07-10-2010, 13:17
|
|
lucil
Registrierter Benutzer
|
|
Registriert seit: Sep 2010
Beiträge: 12
|
|
Hatte das error_reporting(E_ALL); wieder rausgenommen da mir das keine fehler angezeigt hat.
|

07-10-2010, 13:26
|
|
Quetschi
PHP Expert
|
|
Registriert seit: Dec 2004
Beiträge: 2.759
|
|
Hast du neben dem error_reporting auch ini_set('display_errors', 1) gesetzt?
Und was ist mit mysql_error()?
Weiterhin:
Anstelle von irgendwelchen wenig bis nichtssagenden Texten, solltest du lieber durch Ausgaben überprüfen, ob bestimmte Variablen die von dir erwarteten Werte enthalten (am besten mit var_dump() ).
__________________
Drelingdo
Krabonse
Simmannamando
|
|
Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
|
|
|
| Themen-Optionen |
|
|
| Thema bewerten |
|
|
Forumregeln
|
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.
HTML-Code ist aus.
|
|
|
|
PHP News
|