php.de

Zurück   php.de > Webentwicklung > PHP Einsteiger > PHP Tipps 2010

 
 
LinkBack Themen-Optionen Thema bewerten
Alt 08.02.2010, 22:18  
Neuer Benutzer
 
Registriert seit: 08.02.2010
Beiträge: 29
PHP-Kenntnisse:
Anfänger
Unregistrierter befindet sich auf einem aufstrebenden Ast
Standard [Erledigt] Löschfunktion einer SQL-Abfrage in php

Hallo zusammen,

ich habe folgendes Problem:
Ich bin dabei ein Formular bauen, indem ich aus einer Tabelle mehrere Datensätze Abfragen kann.

Das Funktioniert auch soweit. Leider bekomme ich es nicht bewerkstelligt, dort eine Löschfunktion einzubauen.

folgendes habe ich bereits verzapft:
PHP-Code:
<?php   

// Zugriffsdaten

$link mysql_connect('localhost'$dbuser$passwort);
if (!
$link) {
    die(
'keine Verbindung möglich: ' mysql_error());
}

$db_selected mysql_select_db($datenbank$link);
if (!
$db_selected) {
    die (
$datenbank mysql_error());
}

$result mysql_query("SELECT id, host, name, comment  FROM tabellenname ORDER BY `host` DESC");
if (!
$result) {
    echo 
'Abfrage konnte nicht ausgeführt werden: ' mysql_error();
    exit;
}
while (list(
$id$host$name$comment) = mysql_fetch_row($result)) {
    
$content .='
        <tr>
          <td>
            <textarea>' 
$host '</textarea>
          </td>
          <td>' 
$name '</td>
          <td>
            <textarea>' 
$comment '</textarea>
          </td>
          <td>
            <input type="checkbox" name="' 
$id .'" value="delete">
          </td>
        </tr>'
;
      };

echo 
'
      <form method="get">
      <table border="1" >
        <tr>
          <td>IP-Nummer:</td>
          <td>Name:</td>
          <td>Text:</td>
          <td><input type="submit" value="L&ouml;schen" name="button"/></td>
        </tr>
        ' 
$content '
      </table>
      </form>'
;
Leider habe ich vom php nicht wirklich viel Ahnung, und ich komme gar nciht weiter...

Also, die Checkbox hat schon die jeweilige ID, und wenn man die Anklickt, und auf Löschen klickt, dann wird die URL um ?button=L%F6schen&13=delete erweitert, sonst passiert nix
Unregistrierter ist offline  
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 08.02.2010, 23:06  
Erfahrener Benutzer
 
Registriert seit: 05.02.2009
Beiträge: 1.401
PHP-Kenntnisse:
Fortgeschritten
Destruction ist zur Zeit noch ein unbeschriebenes Blatt
Standard

*g*
Du hast ja auch keine Funktion dafür. Was willste nun von uns? Ich denke nicht dass dir hier jemand eben mal so ein Script schreibt. Und wenn doch dann bist du hier falsch => Scriptbörse.
Du hast ja gar keinen Ansatz.
cu
Grüße
Destruction
__________________
"Dummheit redet viel..Klugheit denkt und schweigt.." [Amgervinus]
Destruction ist offline  
Alt 08.02.2010, 23:10  
Erfahrener Benutzer
 
Registriert seit: 28.05.2008
Beiträge: 214
AllOnline ist in Verruf geraten
Standard

Um dir die Richtung zu zeigen:
z.B.: PHP Tutorial - PHP Formular senden und auswerten
es gibt etliche Tutorials.

Genauer musst du eben nach Formularen, Formulardaten auswerten, POST, GET und abfragen googeln.

Wenn du aber eine solche Frage stellst, frage ich mich wie du die SQL-Sachen hin bekommen hast.
__________________
Wer Fehler sucht wird immer welche finden und manche motzen einfach nur so
AllOnline ist offline  
Alt 08.02.2010, 23:22  
Neuer Benutzer
 
Registriert seit: 08.02.2010
Beiträge: 29
PHP-Kenntnisse:
Anfänger
Unregistrierter befindet sich auf einem aufstrebenden Ast
Standard

Zitat:
Um dir die Richtung zu zeigen:
z.B.: PHP Tutorial - PHP Formular senden und auswerten
Danke

Zitat:
Wenn du aber eine solche Frage stellst, frage ich mich wie du die SQL-Sachen hin bekommen hast.
Ich fasse das mal als Lob auf, dass die nun stimmen
Also SQL haben wir in der FH vereinzelt mal gehabt, mit den Programm SQL-Yog (oder so ähnlich) Durften wir ganze Datenbanken schreiben, und darüber auch verknüpfen. Left join, alter Table etc...
PHP haben wir gar nicht gemacht, und bei anderem Code kann man ja abschauen (Bloß ich finde nix, was in Richtung meines Formulars geht...)
Unregistrierter ist offline  
Alt 08.02.2010, 23:37  
Erfahrener Benutzer
 
Registriert seit: 05.02.2009
Beiträge: 1.401
PHP-Kenntnisse:
Fortgeschritten
Destruction ist zur Zeit noch ein unbeschriebenes Blatt
Standard

DELETE FROM ... WHERE
Sollte dir ein Begriff sein.
__________________
"Dummheit redet viel..Klugheit denkt und schweigt.." [Amgervinus]
Destruction ist offline  
Alt 08.02.2010, 23:39  
Erfahrener Benutzer
 
Registriert seit: 28.05.2008
Beiträge: 214
AllOnline ist in Verruf geraten
Standard

Die Frage war ja wie er dahin kommt das er dieses verwenden kann

PHP-Code:
if(isset($_GET['index'])){
  
DELETE FROM ... WHERE ID $_GET....

__________________
Wer Fehler sucht wird immer welche finden und manche motzen einfach nur so
AllOnline ist offline  
Alt 09.02.2010, 00:01  
Neuer Benutzer
 
Registriert seit: 08.02.2010
Beiträge: 29
PHP-Kenntnisse:
Anfänger
Unregistrierter befindet sich auf einem aufstrebenden Ast
Standard

Danke für die weiteren Tipps

Allerdings nochmal eine andere Frage:
PHP Tutorial - PHP Formular senden und auswerten
Dort steht:
Zitat:
<form method="post" action="formularversenden2.php">
Allerdings würde ich alles gerne bei einer Datei belassen, und würde somit den Action-befehl index.php nennen.
Also so:
PHP-Code:
 <form method="get" action="index.php"
geht das?

De Delete-Befehl habe ich auch hier gefunden:
MySQL mit PHP - Tutorial, Datensätze löschen

Allerdings frage ich mich, wie man bei der Abfrage id='$id' mehrere aktivieren soll....
Also folgendes funktioniet schonmal nicht:
PHP-Code:
if(isset($_GET['index'])){
  
mysql_query("DELETE FROM $tabelle1 WHERE id = $_GET[$id]");
}
oder auch
if(isset($_GET['index'])){
  
mysql_query("DELETE FROM $tabelle1 WHERE id = $_GET[name]");
}
bzw.
if(isset(
$_GET['index'])){
  
mysql_query("DELETE FROM $tabelle1 WHERE id = $_GET[delete]");

Ich schau mal weiter...
Unregistrierter ist offline  
Alt 09.02.2010, 02:39  
Neuer Benutzer
 
Registriert seit: 08.02.2010
Beiträge: 29
PHP-Kenntnisse:
Anfänger
Unregistrierter befindet sich auf einem aufstrebenden Ast
Standard

PHP-Code:
<?php   

// Zugriffsdaten

$link mysql_connect('localhost'$dbuser$passwort);
if (!
$link) {
    die(
'keine Verbindung möglich: ' mysql_error());
}

$db_selected mysql_select_db($datenbank$link);
if (!
$db_selected) {
    die (
$datenbank mysql_error());
}

$result mysql_query("SELECT id, host, name, comment  FROM tabellenname ORDER BY `host` DESC");
if (!
$result) {
    echo 
'Abfrage konnte nicht ausgeführt werden: ' mysql_error();
    exit;
}
while (list(
$id$host$name$comment) = mysql_fetch_row($result)) {
    
$content .='
        <tr>
          <td>
            <textarea>' 
$host '</textarea>
          </td>
          <td>' 
$name '</td>
          <td>
            <textarea>' 
$comment '</textarea>
          </td>
          <td>
            <input type="checkbox" name="' 
$id .'" value="1">
          </td>
        </tr>'
;
      };

if(isset(
$_GET['del'])){
  
$content .='Es ist gesetzt';

  print 
"der Wert 1 = ".$_GET['1']."<br>";
  print 
"der Wert 2 = ".$_GET['2']."<br>";
  print 
"der Wert 3 = ".$_GET['3']."<br>";
  print 
"der Wert 4 = ".$_GET['4']."<br>";
  print 
"der Wert 5 = ".$_GET['5']."<br>";
  print 
"der Wert 6 = ".$_GET['6']."<br>";
  print 
"der Wert 7 = ".$_GET['7']."<br>";
  print 
"der Wert 8 = ".$_GET['8']."<br>";

  
mysql_query("DELETE FROM $tabelle WHERE id = $_GET[$id]");
}
mysql_close($link);

echo 
'
      <form method="get" action="index.php"> 
      <table border="1" >
        <tr>
          <td>IP-Nummer:</td>
          <td>Name:</td>
          <td>Text:</td>
          <td><input type="submit" value="entfernen" name="del"/></td>
        </tr>
        ' 
$content '
      </table>
      </form>'
;
So...
Je nachdem, welches Checkbox ich auswähle (zwichern ID 1-8 ), wird mir mit der If-Frage eine 1 Ausgegeben...

Nun muss ich das Ergebnis nur noch in SQL-Abfrage packen...

Ich vermute, ich habe hier noch einen logik-Fehler, denn wenn ich in der Abfrage über GET[$id] gehe, würde ich ja Theoretisch GET[1]..GET[2] uws.. eingeben, dessen Werte alle 1 sind, oder?


Ich glaube, ich muss in die checkbox den namen und das value mit der ID versehen..... Aber morgen...
Unregistrierter ist offline  
Alt 10.02.2010, 19:56  
Neuer Benutzer
 
Registriert seit: 08.02.2010
Beiträge: 29
PHP-Kenntnisse:
Anfänger
Unregistrierter befindet sich auf einem aufstrebenden Ast
Standard

Da ich mir über den print-Befehl die Werte ausgeben lassen kann, und dieses funktioniert, hat das mit dem SQL-Delete zu tun...

Aber ich komme da keinen Schritt weiter....

Der scheint den Wert nicht anzunehmen...
Unregistrierter ist offline  
Alt 11.02.2010, 07:41  
Erfahrener Benutzer
 
Benutzerbild von Arne Drews
 
Registriert seit: 22.04.2009
Beiträge: 3.486
PHP-Kenntnisse:
Anfänger
Arne Drews wird schon bald berühmt werdenArne Drews wird schon bald berühmt werden
Arne Drews eine Nachricht über Skype™ schicken
Standard

PHP-Code:
$_GET['1'
dürfte unter Berücksichtigung von Key/Value-Pairs equivalent zu
PHP-Code:
$
sein und das funktioniert nur bei Rückbezügen, soweit ich informiert bin.

Variablen können imho nicht ausschliesslich aus Zahlen bestehen und müssen zwingend mit Unterstrich oder/und Buchstaben beginnen.

Mach einfach
PHP-Code:
<input type="checkbox" name="myID[]" value="'.$id.'"
und laß Dir mal das Ergebnis mit
PHP-Code:
print_r($_GET); 
ausgeben.

Und entscheide Dich entweder für print oder echo!
Mixen brauchst das nicht. echo reicht für Deine Zwecke...
Arne Drews ist offline  
 


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
Abfrage von einer Abfrage Datenbanken 5 27.01.2011 23:31
Problem mit Abfrage - join, inner join, distinct? Gachet01 Datenbanken 2 27.01.2011 06:49
result Variablen von SQL verbinden vci PHP Tipps 2010 15 05.02.2010 19:09
Scriptsuche [Erledigt] SQL- Abfrage über 2 tabellen ejim Scriptbörse 1 17.07.2009 21:10
SQL Abfrage ohne DESC langsam Thisi Datenbanken 5 07.01.2009 09:53
Wiemache ich eine Abfrage über 3 Tabellen??? djscaleo Datenbanken 8 05.01.2009 10:46
MySQL - Fehler in einfacher Abfrage oden Datenbanken 11 03.01.2009 20:03
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
Abfrage in array? BartTheDevil89 Datenbanken 5 10.05.2005 14:21
[Erledigt] IF() abfrage in variable packen PHP Tipps 2005 14 01.04.2005 17:23
Abfrage von Char-Feldern Datenbanken 9 04.02.2005 14:06
[Erledigt] Mysql Abfrage Problem! PHP-Fortgeschrittene 5 27.11.2004 10:22
Abfrage funktioniert zwar, aber nicht korrekt Datenbanken 2 16.08.2004 09:10
Abfrage aus DB noch mal ausgeben und Abfrage aus mehrern Tab PHP Tipps 2004 4 12.07.2004 15:00
[Erledigt] Fehlerhafte Abfrage ? Datenbanken 15 24.06.2004 17:10

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
php löschfunktion, php function sql, löschfunktion php, php funktionen für sql, php function sql-abfrage, in html function sql anweisung, löschfunktion sql, php lösch funktion, http://www.php.de/php-einsteiger/64391-erledigt-loeschfunktion-einer-sql-abfrage-php.html, delete * from where, sql abfrage in funktion, php sql löschen button, lösch funktion php, löschfunktion um eigene beiträge zu löschen php html, sql abfrage löschen button, sql query delete unterroutinen, funktion löschen php, sql php funktion, löschfunktion in sql, löschfunktion in php

Alle Zeitangaben in WEZ +2. Es ist jetzt 21:23 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum