php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > PHP Developer Forum
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 


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! Fragen zu Laravel, YII oder anderen PHP-Frameworks.

Antwort
 
LinkBack Themen-Optionen Thema bewerten
  #1 (permalink)  
Alt 14-03-2005, 00:18
fain7
 Newbie
Links : Onlinestatus : fain7 ist offline
Registriert seit: Mar 2005
Beiträge: 4
fain7 ist zur Zeit noch ein unbeschriebenes Blatt
Standard Problem mit Suche

Hallo zusammen, mein erster Post hier und gleich mit nem Problem...

Ich habe eine Datenbankabfrage, die mir ziemlich Kopfschmerzen bereitet.
Erstmal zur Erklärung: Es geht um eine Suchfunktion in einer MySQL Datenbank, die nur mit Checkboxen und Pulldowns arbeitet.

Bei dieser Suche hat der User die Möglichkeit Stichwörter mit den Checkboxen ("Ich kann dies und jenes tun") und Tageszeiten mit den Pulldowns ("Vormittag, Nachmittag...") zu suchen. Soweit so gut.

Nun möchte ich, dass in dem Suchergebniss ALLE Datensätze ausgegeben werden sollen, in welchen die Stichwörter gegeben sind, und ALLE Datensätze in denen die Tageszeit vorkommt.

PHP-Code:
<?

$stunden
=implode(" , ",$HTTP_POST_VARS["stunden"]); 
$montag $HTTP_POST_VARS["montag"];
$dienstag $HTTP_POST_VARS["dienstag"];
$mittwoch $HTTP_POST_VARS["mittwoch"];
$donnerstag $HTTP_POST_VARS["donnerstag"];
$freitag $HTTP_POST_VARS["freitag"];
$samstag $HTTP_POST_VARS["samstag"];
$sonntag $HTTP_POST_VARS["sonntag"];
 
$conn_id mysql_connect("xxx","xxx","xxx"); 
mysql_select_db("xxx",$conn_id);

$sql "SELECT stunden, montag, dienstag, mittwoch, donnerstag, freitag, samstag, sonntag FROM meine_tabelle WHERE 
stunden  LIKE '%$stunden%' AND
montag LIKE '$montag' AND
dienstag LIKE '$dienstag' AND
mittwoch    LIKE '$mittwoch' AND
donnerstag LIKE '$donnerstag' AND
freitag LIKE '$freitag' AND
samstag LIKE '$samstag' AND
sonntag    LIKE '$sonntag'"
;
$result mysql_query($sql);
while (
$row mysql_fetch_array($result))

...

?>
Mit diesem Code werden ja die Ergebnisse ausgegeben, in welchen alle genannten Variablen zusammenkommen; Wenn ich allerdings nur nach Mittwoch suche und die anderen Felder leer lasse, bekomme ich keine Ergebnisse. Wenn ich die selbe Suche in PHPmyAdmin von Hand mache klappt, aber da fülle ich ja auch nur die Felder aus, nach denen ich suche.

Nun (endlich) meine konkrete Frage: wie kann ich erreichen, dass die Datenbank nun nach z.B. nur den Inhalt "Mittwoch" ausgibt wenn nur Mittwoch angegeben ist, und die anderen Tage ausser acht läßt??

Ich hoffe dieser Post is jetzt richtig formatiert (mit dem Code) und ich hab mich verständlich ausgedrückt. Wenn nicht - seht es mit bitte nach - ich versuch mich zu bessern

Geändert von fain7 (14-03-2005 um 01:29 Uhr)
Mit Zitat antworten
  #2 (permalink)  
Alt 14-03-2005, 00:32
Shurakai
 Master
Links : Onlinestatus : Shurakai ist offline
Registriert seit: May 2004
Ort: Bergisch Gladbach
Beiträge: 3.084
Shurakai ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Ich würde es vermutlich mit dem ?-Operator von PHP machen und somit den SQL-Code dynamisch generieren.

P.S.: http://php-resource.de/forum/showthr...threadid=50454

Code ist leider nicht richtig formatiert, weil die PHP-Tags fehlen *g*
Mit Zitat antworten
  #3 (permalink)  
Alt 14-03-2005, 00:46
fain7
 Newbie
Links : Onlinestatus : fain7 ist offline
Registriert seit: Mar 2005
Beiträge: 4
fain7 ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Danke ich werde mal sehen, dass ich den Code dann zukünftig richtig reintu...

Zu meinem Prob: Ich denke super wäre in meinem Fall, wenn ich verhindern könnte, dass die leeren Felder mitübergeben werden und damit das Suchergebniss vermurksen. Sprich wenn nur unter Mittwoch eine Zeit angegeben ist, wird auch nur der Mittwoch in die Suche miteinbezogen.

Kann ich davon ausgehen dass

PHP-Code:
<?php
if (!empty($_POST['tagesname']));
?>
da mein Freund ist? Leider kenne ich mich dem Befehl nich aus und wäre für ein Beispiel im Sinne von "wenn das Feld leer is wird auch nich danach in der Datenbank gesucht" mehr als dankbar.
Mit Zitat antworten
  #4 (permalink)  
Alt 14-03-2005, 01:27
penizillin
 PHP Guru
Links : Onlinestatus : penizillin ist offline
Registriert seit: Feb 2004
Beiträge: 10.166
penizillin ist zur Zeit noch ein unbeschriebenes Blatt
Standard

editieren kannst du den post immer noch.

PHP-Code:
if(!empty($x)) {
    
$sql .= " OR bla ";

Mit Zitat antworten
  #5 (permalink)  
Alt 14-03-2005, 01:35
fain7
 Newbie
Links : Onlinestatus : fain7 ist offline
Registriert seit: Mar 2005
Beiträge: 4
fain7 ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Okey dokey, hab ich jetzt mal schnell nachgeholt.

Ja das Beispiel is klar. Hätte ich jetzt wohl auch so gemacht.

Allerdings ergibt sich da das Problem, dass die Woche ja 7 Tage hat.
Wenn man es nach diesem Ausschlussverfahren angeht, müßte ich ja 7x7 (oder 7hoch7?) mögliche abfragen angeben. Es muss doch da ne andere Möglichkeit geben, von 7 Feldern die in einem Formular übergeben werden nur die nicht leeren in die Suche mit aufzunehmen?

Vielen Dank erstmal für die Hilfe soweit btw.
Mit Zitat antworten
  #6 (permalink)  
Alt 14-03-2005, 01:38
penizillin
 PHP Guru
Links : Onlinestatus : penizillin ist offline
Registriert seit: Feb 2004
Beiträge: 10.166
penizillin ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Zitat:
Wenn man es nach diesem Ausschlussverfahren angeht, müßte ich ja 7x7 (oder 7hoch7?) mögliche abfragen angeben.
warum?
Mit Zitat antworten
  #7 (permalink)  
Alt 14-03-2005, 02:13
fain7
 Newbie
Links : Onlinestatus : fain7 ist offline
Registriert seit: Mar 2005
Beiträge: 4
fain7 ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Ja, gute Frage. Doof von mir, der check is ja "ob nicht leer". Is halt schon spät

Ich werd damit mal rumtüfteln. Danke erstmal
Mit Zitat antworten
Antwort

Lesezeichen


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Themen-Optionen
Thema bewerten
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.

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


PHP News

Vorteile eines flexiblen ERP Systems
Vorteile eines flexiblen ERP SystemsEin flexibles ERP System bietet in allen Unternehmensbereichen die Grundlage für eine erfolgreiche Verwaltung, Organisation und Planung aller Prozesse.

01.12.2021 | Berni

Software für alle Arten von digitalen Marktplätzen
Software für alle Arten von digitalen MarktplätzenDigitale Marktplätze sind nicht nur im B2C Geschäft seit Jahren etabliert, sondern erfreuen sich mit Kleinanzeigen-Märkten auf lokaler und regionaler Ebene auch im privaten Bereich wachsender Beliebtheit.

09.11.2021 | Berni


 

Aktuelle PHP Scripte

ebiz-trader 6.0 - Das professionelle PHP Marktplatz Script ansehen ebiz-trader 6.0 - Das professionelle PHP Marktplatz Script

Mit unserer Lösungen können Sie nahezu jeden B2B / B2C Marktplatz betreiben den Sie sich vorstellen können. Ganz egal ob Sie einen Automarktplatz, Immobilenportal oder einfach einen Anzeigenmarkt betreiben möchten. Mit ebiz-trader können Sie Ihre Anforder

09.11.2021 Berni | Kategorie: PHP/ Anzeigenmarkt
PHP Newsletter Script SuperWebMailer ansehen PHP Newsletter Script SuperWebMailer

Die webbasierte PHP Newsletter Software SuperWebMailer ist die optimale Lösung zur Durchführung eines erfolgreichen E-Mail-Marketings. Zur Nutzung des PHP Script-Pakets ist eine eigene Webpräsenz/Server mit PHP 5 oder neuer, MySQL 4 oder neuer und die

28.10.2021 mirko_swm | Kategorie: PHP/ Mail
Guestbook Light ansehen Guestbook Light

Das Guestbook Light (kurz: "Gblight") ist ein kinderleichtes Gästebuch in PHP. Durch den Einsatz einer SQLite Datenbank ist es einfach, leicht portabel und schnell. Aufgrund moderner Techniken erfüllt Gblight auch die neuesten Webstandards.

28.10.2021 scripthostingnet | Kategorie: PHP/ Gaestebuch
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 14:30 Uhr.