[GastForen Programmierung/Entwicklung PHP und MySQL Array in eine Suchanfrage áuslesen

  • Suche
  • Hilfe
  • Lesezeichen
  • Benutzerliste
Themen
Beiträge
Moderatoren
Letzter Beitrag

Array in eine Suchanfrage áuslesen

Anonym
Beiträge gesamt: 22827

26. Jan 2004, 16:22
Beitrag # 1 von 8
Bewertung:
(1510 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
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...
X

Array in eine Suchanfrage áuslesen

StefanB
Beiträge gesamt:

26. Jan 2004, 16:45
Beitrag # 2 von 8
Beitrag ID: #67397
Bewertung:
(1510 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Ach, sorry, hab' schon wieder vergessen, mich vorher einzuloggen. Der Anonymus bin ich. Stefan


als Antwort auf: [#67391]

Array in eine Suchanfrage áuslesen

Pozor
Beiträge gesamt: 892

26. Jan 2004, 17:21
Beitrag # 3 von 8
Beitrag ID: #67410
Bewertung:
(1510 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
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)

Array in eine Suchanfrage áuslesen

StefanB
Beiträge gesamt:

26. Jan 2004, 18:03
Beitrag # 4 von 8
Beitrag ID: #67413
Bewertung:
(1510 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
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]

Array in eine Suchanfrage áuslesen

Pozor
Beiträge gesamt: 892

26. Jan 2004, 18:43
Beitrag # 5 von 8
Beitrag ID: #67421
Bewertung:
(1510 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
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)

Array in eine Suchanfrage áuslesen

Pozor
Beiträge gesamt: 892

26. Jan 2004, 18:46
Beitrag # 6 von 8
Beitrag ID: #67422
Bewertung:
(1510 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
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]

Array in eine Suchanfrage áuslesen

StefanB
Beiträge gesamt:

27. Jan 2004, 08:48
Beitrag # 7 von 8
Beitrag ID: #67488
Bewertung:
(1510 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
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]

Array in eine Suchanfrage áuslesen

StefanB
Beiträge gesamt:

18. Feb 2004, 15:24
Beitrag # 8 von 8
Beitrag ID: #71085
Bewertung:
(1510 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
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]
X

Veranstaltungskalender

Hier können Sie Ihre Anlässe eintragen, welche einen Zusammenhang mit den Angeboten von HilfDirSelbst.ch wie z.B. Adobe InDesign, Photoshop, Illustrator, PDF, Pitstop, Affinity, Marketing, SEO, Büro- und Rechtsthemen etc. haben. Die Einträge werden moderiert freigeschaltet. Dies wird werktags üblicherweise innert 24 Stunden erfolgen.

pdf-icon Hier eine kleine Anleitung hinsichtlich Bedeutung der auszufüllenden Formularfelder.

Veranstaltungen
14.05.2024

Online
Dienstag, 14. Mai 2024, 10.00 - 10.30 Uhr

Webinar

Prozessoptimierung ist ein Teamsport! Keine Software und keine Maschine allein kann Ihnen helfen, die Effizienzpotenziale Ihres Betriebes maximal auszuschöpfen. Von der Auftragsannahme über die Vorstufe und den Druck bis hin zur Weiterverarbeitung – alles muss optimal ineinandergreifen. Apropos Weiterverarbeitung – in vielen Druckbetrieben fristet sie in Sachen Prozessoptimierung immer noch ein Schattendasein. Dabei liegen hier mittlerweile die größten Einsparpotenziale! In einem Webinar von Horizon und Impressed erfahren Sie, wie Sie diese Einsparungen realisieren können. Horizon, bekannt für innovative Lösungen in der Druckweiterverarbeitung, bietet mit iCE LiNK eine Workflowlösung für die Weiterverarbeitung. iCE LiNK überwacht, visualisiert und analysiert Produktionsabläufe und unterstützt bei der Wartung – damit immer alles reibungslos läuft. Den gleichen Anspruch hat der von Impressed entwickelte Impressed Workflow Server – er ist die smarte PDF-Workflow-Lösung für Druckereien, die Datenmanagement, Preflight und Produktionssteuerung übernimmt. Im Webinar zeigen Ihnen die Experten von Horizon und Impressed, wie beide Lösungen im Team die Effizienz und Produktivität Ihres Betriebes steigern können. Melden Sie sich am besten gleich an, wir freuen uns auf Sie! PS: Melden Sie sich in jedem Fall an – sollten Sie zum Termin verhindert sein, erhalten Sie die Aufzeichnung.

kostenlos

Ja

Organisator: Impressed / Horizon

https://www.impressed.de/schulung.php?c=sDetail&sid=327

Einsparpotenziale in der Weiterverarbeitung
Veranstaltungen
16.05.2024

Online
Donnerstag, 16. Mai 2024, 10.00 - 10.30 Uhr

Webinar

Komplizierte, kleinteilige Aufträge; alles sehr speziell; seit Jahren bewährte Prozesse – da können wir nichts standardisieren und automatisieren! Das sagen viele Großformatdrucker – aber stimmt das wirklich, ist dem tatsächlich so? Günther Business Solutions und Impressed treten in einem Webinar den Gegenbeweis an. Experten beider Unternehmen zeigen, wie Großformatdrucker vom Einsatz zweier bewährter Lösungen profitieren können: • von advanter print+sign von Günther Business Solutions, dem ERP-System für den Großformatdruck, dass alle Phasen der Wertschöpfung im Large Format Printing abdeckt • von Impressed Workflow Server, der smarten PDF-Workflow-Lösung für Druckereien, die Datenmanagement, Preflight und Produktionssteuerung übernimmt Über die Kombination beider Lösungen können Großformatdrucker ihre Prozesse mit modernen Workflows Schritt für Schritt automatisieren – und so zügig deutliche Zeit- und Kosteneinsparungen realisieren. Das Webinar sollten Sie sich nicht entgehen lassen – damit Sie keine Effizienzpotenziale mehr liegen lassen. Melden Sie sich am besten gleich an, wir freuen uns auf Sie! PS: Melden Sie sich in jedem Fall an – sollten Sie zum Termin verhindert sein, erhalten Sie die Aufzeichnung.

kostenlos

Nein

Organisator: Impressed / Günther Business Solutions

https://www.impressed.de/schulung.php?c=sDetail&sid=326

Und es geht doch: Automatisierung im Großformatdruck!