| 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! |
 |

29-05-2001, 12:07
|
|
BigMick
Newbie
|
|
Registriert seit: May 2001
Beiträge: 7
|
|
Tach zusammen,
langsam werd' ich mürbe.
Ein simples HTML-Formular das ein einziges Feld an ein PHP-Script übergibt. Klingt simpel. Nur dass die Variable nicht vom PHP-Script angenommen wird.
----Formular:
<form action="testsuche2.php3" method="get">
<b>Suchbegriff</b> <input type="text" value="" name="suchbeg" size="7" maxlength="5"> <input type="submit" value="Suchen" name="submit">
----testsuche.php3:
<?
print "Ihr Suche nach $suchbeg ergab folgende Ergebnisse";
?>
...
<?
$abfrage = "SELECT AboNr, Name, Email, PLZ FROM Abo WHERE (PLZ LIKE '$suchbeg%') ";
$erg = mysql_db_query("testsuche",$abfrage,$verbindung);
while ($row = mysql_fetch_array($erg)) {
$AboNr = $row['AboNr'];
$Name = $row['Name'];
$Email = $row['Email'];
$PLZ = $row['PLZ'];
print "<tr bgcolor=#ffffff><td><font face=arial size=2>$AboNr</font></td><td><font face=arial size=2>$Name</font></td><td>$Email</td><td>$PLZ</td></tr>";
}
?>
Es wird einfach immer eine leere Variable übergben, so dass
das PHP-Script immer alle Einträge anzeigt.
Irgendjemand vielleicht eine Idee? Bin ich schlichtweg zu blöd?
Michael
|

29-05-2001, 13:47
|
|
Walter
Newbie
|
|
Registriert seit: May 2001
Beiträge: 50
|
|
Hallo Michael,
ich bin zwar ein blutiger Anfänger, soweit ich aber bis jetzt mitgekriegt habe, funktioniert der direkte Zugriff auf die Variable nur mit der Methode Post, bei Get muss man glaube ich die globale Variable $QUERY_STRING auswerten.
!! War nur ein Versuch, bitte nicht gleich erschlagen, wenn ich falsch liege !!
Gruss Walter
|

29-05-2001, 14:09
|
|
BigMick
Newbie
|
|
Registriert seit: May 2001
Beiträge: 7
|
|
Variable aus HTML-Form an PHP 2.
Zitat:
Original geschrieben von Walter
Hallo Michael,
ich bin zwar ein blutiger Anfänger, soweit ich aber bis jetzt mitgekriegt habe, funktioniert der direkte Zugriff auf die Variable nur mit der Methode Post, bei Get muss man glaube ich die globale Variable $QUERY_STRING auswerten.
!! War nur ein Versuch, bitte nicht gleich erschlagen, wenn ich falsch liege !!
Gruss Walter
|
Danke dir, aber mit Post ist es dasselbe.;-(
|

29-05-2001, 17:51
|
|
hannes
PHP-Süchtiger
|
|
Registriert seit: May 2001
Beiträge: 200
|
|
Versuchs mal mit $row[PLZ]
ohne die ''
|

29-05-2001, 23:34
|
|
Arni
PHP Junior
|
|
Registriert seit: Mar 2001
Ort: Miami F.L
Beiträge: 691
|
|
Hi
Versche es mal so
$abfrage = "SELECT AboNr, Name, Email, PLZ FROM Abo WHERE PLZ LIKE '%$suchbeg%') ";
und las das value="" mal ganz weg
<input type="text" name="suchbeg"
Gruß
Arni
|

30-05-2001, 07:37
|
|
Wolfgang13
Newbie
|
|
Registriert seit: May 2001
Ort: Wien
Beiträge: 53
|
|
So wie Du das Script laufen läßt, wird zuerst für "suchbeg" ein Wert abgefragt, dann rufts Du mit Submit die Seite neu auf und ersetzt ihn gleich wieder durch eine leere Zeichenfolge, wenn Du wieder durch das Formular gehst.
Möglichkeit 1:
<?
if(!empty($suchbeg)) {
print "Ihre Suche nach $suchbeg ergab folgende Ergebnisse";
}
?>
...
<?
$abfrage = "SELECT AboNr, Name, Email, PLZ FROM Abo WHERE (PLZ LIKE '$suchbeg%') ";
$erg = mysql_db_query("testsuche",$abfrage,$verbindung);
while ($row = mysql_fetch_array($erg)) {
$AboNr = $row['AboNr'];
$Name = $row['Name'];
$Email = $row['Email'];
$PLZ = $row['PLZ'];
print "<tr bgcolor=#ffffff><td><font face=arial size=2>$AboNr</font></td><td><font face=arial size=2>$Name</font></td><td>$Email</td><td>$PLZ</td></tr>";
}
?>
<form action="testsuche2.php3" method="get">
<b>Suchbegriff</b> <input type="text" value="" name="suchbeg" size="7" maxlength="5"> <input type="submit" value="Suchen" name="submit">
Möglichkeit 2:
<form action="testsuche2.php3" method="get">
<b>Suchbegriff</b> <input type="text" value="<? echo $suchbeg ?>" name="suchbeg" size="7" maxlength="5"> <input type="submit" value="Suchen" name="submit">
if(!empty($suchbeg)) {
print "Ihre Suche nach $suchbeg ergab folgende Ergebnisse";
}
?>
...
<?
$abfrage = "SELECT AboNr, Name, Email, PLZ FROM Abo WHERE (PLZ LIKE '$suchbeg%') ";
$erg = mysql_db_query("testsuche",$abfrage,$verbindung);
while ($row = mysql_fetch_array($erg)) {
$AboNr = $row['AboNr'];
$Name = $row['Name'];
$Email = $row['Email'];
$PLZ = $row['PLZ'];
print "<tr bgcolor=#ffffff><td><font face=arial size=2>$AboNr</font></td><td><font face=arial size=2>$Name</font></td><td>$Email</td><td>$PLZ</td></tr>";
}
?>
|

30-05-2001, 09:26
|
|
BigMick
Newbie
|
|
Registriert seit: May 2001
Beiträge: 7
|
|
Danke Arni für die Hilfe,
aber ohne Value der gleiche Effekt.
Das % vor dem $suchbeg habe ich weg gelassen, da ich nur die
Werte ausgeben will, die mit $suchbeg BEGINNEN.
Michael
|

30-05-2001, 09:32
|
|
BigMick
Newbie
|
|
Registriert seit: May 2001
Beiträge: 7
|
|
Danke Wolfgang,
aber das Script ruft sich nicht selbst auf, da es ZWEI unterschiedliche Dateien sind.
Ich kann natürlich auch noch eine Abfrage auf empty durchführen, aber an meinem Problem ändert das leider nichts.
Michael
|
|
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
|