hilfdirselbst.ch
Facebook Twitter gamper-media
Anonym
Beiträge: 22827
26. Jan 2004, 16:22
Beitrag #1 von 8
Bewertung:
(1162 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen

Array in eine Suchanfrage áuslesen


Hallo,
folgendes Problem kann ich mit meinem PHP-Einsteigerhirn nicht lösen:
Auf einer Auswahlseite können Bilder via Checkboxes (name=auswahl[], value = die Bildnummer) ausgewählt werden. Das Array $auswahl enthält nun die ausgewählten Bildnummern, z.B. 00001, 00002 etc., und wird auf die nächste Seite mitgenommen. Soweit habe ich es hinbekommen. Hier nun soll daraus eine mySQL-Anfrage erzeugt werden, um Detailinfos abzurufen:

"SELECT * FROM bilder WHERE $suchstring "

Der Suchstring soll dann je nach vorausgewählten Bildern beinhalten:
"bildnr = 00001 OR bildnr = 00002 OR ..."

Wie kann ich aus dem Array $auswahl einen Suchstring $suchstring erzeugen, der diese SELECT-Anfrage beinhaltet?

Mit folgender Funktion bekomme ich das Gewünschte zwar auf den Bildschirm, aber das nützt mir für die SELECT-Anfrage ja nix:
-----------------------------------------
function ausgeben($x)
{
global $counter, $auswahl;
if($counter < count($auswahl))
{
echo("bildnr = $x OR ");
$counter++;
}
else
{
echo("bildnr = $x");
}
}
$counter=1;
global $counter, $auswahl;
array_walk($auswahl, "ausgeben");
--------------------------------------
Wie gesagt, so habe ich's via echo zwar auf dem Schirm, aber noch nicht in der Abfrage. Wie bekomme ich das hin?

Danke, Stefan

Dies ist die erste von $werweisswieviel Fragen... Top
 
X
StefanB
Beiträge: 71
26. Jan 2004, 16:45
Beitrag #2 von 8
Beitrag ID: #67397
Bewertung:
(1162 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen

Array in eine Suchanfrage áuslesen


Ach, sorry, hab' schon wieder vergessen, mich vorher einzuloggen. Der Anonymus bin ich. Stefan
als Antwort auf: [#67391] Top
 
Pozor  M 
Beiträge: 892
26. Jan 2004, 17:21
Beitrag #3 von 8
Beitrag ID: #67410
Bewertung:
(1162 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen

Array in eine Suchanfrage áuslesen


Hallo,

bildnr = 00001 OR bildnr = 00002 OR ...

wie wäre es mit

$suchstring = '';
$size = sizeof($array);

for ($i = 0; $i < $size; $i++)
{
$suchstring .= ' bildnr = '.$array[$i].' ';
if(!(1 < $size) or ($i != $size-1))
{
//so sollte es bei nur einem bild kein or anhängen
//und beim letzten bild auch kein zusätzliches or anhängen
$suchstring .= ' OR ';
}
}


gruss Pozor
als Antwort auf: [#67391]
(Dieser Beitrag wurde von Pozor am 26. Jan 2004, 17:27 geändert)
Top
 
StefanB
Beiträge: 71
26. Jan 2004, 18:03
Beitrag #4 von 8
Beitrag ID: #67413
Bewertung:
(1162 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen

Array in eine Suchanfrage áuslesen


Hallo Pozor,

danke! Hab's abgetippt (aber noch nicht kapiert...).

Funzt fast, aber eben noch nicht ganz. Wenn ich $suchstring mit echo ausgebe, steht hinten immer noch ein OR. Vielleicht klappt die Suchanfrage deshalb noch nicht.

Werde mich da aber mal weiter durchbeißen und erstmal versuchen, das Skript zu verstehen. Besten Dank für den Tipp!

Stefan
als Antwort auf: [#67391] Top
 
Pozor  M 
Beiträge: 892
26. Jan 2004, 18:43
Beitrag #5 von 8
Beitrag ID: #67421
Bewertung:
(1162 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen

Array in eine Suchanfrage áuslesen


hallo,

ich habe es ohne zu testen hingeschrieben, doch habe ich es nachträglich korrigiert! die letzte Version lauft. Ich habe sie jetzt nocht getestet und es funzt wie es sollte

http://develop.ch/hds/test.php

gruss Pozor
als Antwort auf: [#67391]
(Dieser Beitrag wurde von Pozor am 26. Jan 2004, 18:47 geändert)
Top
 
Pozor  M 
Beiträge: 892
26. Jan 2004, 18:46
Beitrag #6 von 8
Beitrag ID: #67422
Bewertung:
(1162 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen

Array in eine Suchanfrage áuslesen


hallo,

ich habe das file in ein anderen Ordner verschobven:

http://develop.ch/hds/test.php

zusätzlich benötigen die zahlen (001 etc) noch hochkommas (glaube ich)
In dieser Version habe ich es kurz eingebaut.

Gruss Pozor
als Antwort auf: [#67391] Top
 
StefanB
Beiträge: 71
27. Jan 2004, 08:48
Beitrag #7 von 8
Beitrag ID: #67488
Bewertung:
(1162 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen

Array in eine Suchanfrage áuslesen


Danke Pozor!

Es hat geklappt mit folgenden Modifikationen:

- für die SQL-Anfrage Bildnummern ohne Hochkommata;

- in der Zeile

"if(!(1 < $size..."

das "<" ersetzen durch "<=", damit das letzte "OR" auch wegfällt, wenn das Array nur einen einzigen Eintrag enthält.

Vielen Dank!
Stefan
als Antwort auf: [#67391] Top
 
StefanB
Beiträge: 71
18. Feb 2004, 15:24
Beitrag #8 von 8
Beitrag ID: #71085
Bewertung:
(1162 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen

Array in eine Suchanfrage áuslesen


Hier ist der funktionierende Code:

//umwandeln array in suchstring
$suchstring = '';
$size = sizeof($b);
for ($i = 0; $i < $size; $i++)
{
$suchstring .= " bildnr = ".$b[$i]." ";
if(!(1 <= $size) or ($i != $size-1)
{
$suchstring .= ' OR ';
}
}
$sql = "SELECT xxx FROM yyy WHERE $suchstring";

Gruß, Stefan
als Antwort auf: [#67391] Top
 
X