php.de

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

 
 
LinkBack Themen-Optionen Thema bewerten
Alt 15.05.2007, 13:43  
Benutzer
 
Registriert seit: 15.05.2007
Beiträge: 35
Wing ist zur Zeit noch ein unbeschriebenes Blatt
Wing eine Nachricht über ICQ schicken
Standard Vereinfachung einer sql-abfrage für jeden leserlich darstell

Guten Tag,


ich habe ein Script geschrieben, mit dem jeder Besucher seinen eigenen Filter zusammenstellen kann. Der Filter wird als Bestätigung nochmal auf der Webseite angezeigt. Er wird über str_replace direkt von der SQL-Abfrage abgewandelt.

Im Moment sieht das ganze so aus:
Zitat:
SELECT userID FROM db WHERE name = 'Wing' AND (klasse = 'WG11/1' OR klasse = 'Freizeitklasse' OR klasse = 'WG12/1') AND (kapitelID = '12' OR kapitelID = '6' OR kapitelID = '18' OR kapitelID = '36' OR kapitelID = '1' OR kapitelID = '39') AND sprachen = '1';
Zitat:
Filter: Daten von Wing und (klasse = WG11/1 oder klasse = Freizeitklasse oder klasse = WG12/1) und (kapitelID = 12 oder kapitelID = 6 oder kapitelID = 18 oder kapitelID = 36 oder kapitelID = 1 oder kapitelID = 39) und sprachen = 1:
Der Code ist im Moment noch relativ einfach:
PHP-Code:
    $sql "SELECT userID FROM db WHERE".$filterstring;

    echo 
$sql."

\n"
;

    
$einfach str_replace("SELECT userID FROM db WHERE name = '""Filter: Daten von [b]"$sql);
    
$einfach str_replace("' AND ""[/b] [i]und[/i] "$einfach);
    
$einfach str_replace("'"""$einfach);
    
$einfach str_replace("OR""[i]oder[/i]"$einfach);
    
$einfach str_replace("AND""[i]und[/i]"$einfach);
    
$einfach str_replace(";"":"$einfach);

    echo 
$einfach;

    
$result mysql_query($sql) OR die(mysql_error());
// ...... 

Jetzt sieht man hier ja so oft "oder kapitelID = '36' oder " usw. Hier meine Frage: Welche Methoden gibt es, das ganze vereinfacht darzustellen, in etwa so: "bei denen Kapitel = 1, 2, 3, 12, 36 ist."

mfg Wing
Wing ist offline  
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 15.05.2007, 15:47  
moderatives Dielektrikum
 
Benutzerbild von nikosch
 
Registriert seit: 21.05.2008
Beiträge: 35.987
PHP-Kenntnisse:
Fortgeschritten
nikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunft
Standard

in SQL: WHERE value IN(1,2,3)
nikosch ist offline  
Alt 15.05.2007, 16:03  
Benutzer
 
Registriert seit: 15.05.2007
Beiträge: 35
Wing ist zur Zeit noch ein unbeschriebenes Blatt
Wing eine Nachricht über ICQ schicken
Standard

SELECT userID FROM db WHERE name = 'Wing' AND klasse IN( 'WG11/1' , 'Freizeitklasse' , 'WG12/1') AND kapitelID IN (12, 6, 18, 36, 1, 39) AND sprachen = '1';


so? geht das? ich kenne den befehl IN() nicht.
Wing ist offline  
Alt 15.05.2007, 18:57  
Erfahrener Benutzer
 
Registriert seit: 12.05.2005
Beiträge: 1.038
PHP-Kenntnisse:
Fortgeschritten
notyyy befindet sich auf einem aufstrebenden Ast
Standard

http://ffm.junetz.de/members/reeg/DS...00000000000000

notyyy ist offline  
Alt 15.05.2007, 19:51  
Benutzer
 
Registriert seit: 15.05.2007
Beiträge: 35
Wing ist zur Zeit noch ein unbeschriebenes Blatt
Wing eine Nachricht über ICQ schicken
Standard

Ah genau. Jetzt sieht mein Code um einiges besser aus.


danke dir
Wing 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
mysql abfrage in Schleife havok PHP Tipps 2006 6 09.05.2006 08:39
abfrage begrenzen Cyrus Datenbanken 4 26.10.2005 11:29
[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] SQL Abfrage funzt nicht Datenbanken 2 04.02.2005 11:09
[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
komplizierte mySQL Abfrage Datenbanken 6 25.06.2004 15:34
[Erledigt] Fehlerhafte Abfrage ? Datenbanken 15 24.06.2004 17:10
[Erledigt] mysql Abfrage Datenbanken 5 18.06.2004 14:16
[Erledigt] Variable per GET übergeben und DB Abfrage nutzen PHP Tipps 2004 4 01.06.2004 15:17

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
sql abfragen leserlich

Alle Zeitangaben in WEZ +2. Es ist jetzt 16:29 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

Creative Commons License
Dieser Inhalt ist unter einer Creative Commons-Lizenz lizenziert.