php.de

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

 
 
LinkBack Themen-Optionen Thema bewerten
Alt 24.01.2009, 19:33  
Neuer Benutzer
 
Registriert seit: 13.01.2009
Beiträge: 7
k1nGk0oL befindet sich auf einem aufstrebenden Ast
Standard [Erledigt] Suchfunktion mit mehreren Feldern

Hallo,

ich habe ein kleines Problem, ich will eine Suchfunktion anbieten, wobei man vier Suchfelder hat. Man soll die Möglichkeit haben auch ein Feld auszulassen.

Mein Problem hierbei ist, dass ich es entweder hinkriege das nur Datensätze ausgegeben werden, die nur mit EINEM Suchfeld übereinstimmen (mit OR Operator) oder das
man gar nichts ausgegeben bekommt weil alles mit dem AND Operator verbunden ist, und , wie oben beschrieben, auch leere Felder erlaubt sind.

Wenn mein Problem verstanden wurde, wäre eine kleine Hilfe sehr nett. Danke schonmal.

Mein aktueller SQL Query:
Code:
SELECT 
	*
 FROM 
	tabelle
 WHERE ('$a' IS NULL OR a = '$a')
   AND ('$b' IS NULL OR b = '$b')
   AND ('$c' IS NULL OR c = '$c')
   AND ('$d' IS NULL OR d = '$d')
k1nGk0oL ist offline  
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 24.01.2009, 20:12  
Erfahrener Benutzer
 
Registriert seit: 19.05.2008
Beiträge: 612
PHP-Kenntnisse:
Fortgeschritten
Young Jedi befindet sich auf einem aufstrebenden Ast
Standard

Hmm '$a' IS NULL - das kann ja eigentlich gar nicht stimmen. Du kannst es ja mal mit
Code:
('$a' = '' OR a = '$a')
probieren.

mfg
__________________
http://tippsgegenlangeweile.de

Young Jedi ist offline  
Alt 24.01.2009, 20:41  
Moderator
 
Benutzerbild von Chriz
 
Registriert seit: 11.05.2008
Beiträge: 6.269
Chriz ist ein wunderbarer AnblickChriz ist ein wunderbarer AnblickChriz ist ein wunderbarer AnblickChriz ist ein wunderbarer AnblickChriz ist ein wunderbarer AnblickChriz ist ein wunderbarer AnblickChriz ist ein wunderbarer Anblick
Standard

Warum übergibst du den Teil überhaupt an SQL, wenn z.B. $a leer ist?
Chriz ist offline  
Alt 24.01.2009, 20:49  
Neuer Benutzer
 
Registriert seit: 13.01.2009
Beiträge: 7
k1nGk0oL befindet sich auf einem aufstrebenden Ast
Standard

Wenn ich das so schreibe:
Code:
SELECT 
	*
 FROM 
	tabelle
 WHERE ('$a' = '' OR a = '$a')
   AND ('$b' = '' OR b = '$b')
   AND ('$c' = '' OR c = '$c')
   AND ('$d' = '' OR d = '$d')
und nur beim Feld a was eingebe.. dann gibt er mir gar kein Wert raus. Wahrscheinlich weil er dann $b, $c ,$d mit dem Wert '' übergibt und dafür kein entsprechender Datensatz existiert.

Liegt es am Query oder kann man das auch anders lösen?
k1nGk0oL ist offline  
Alt 24.01.2009, 20:52  
Erfahrener Benutzer
 
Registriert seit: 19.05.2008
Beiträge: 612
PHP-Kenntnisse:
Fortgeschritten
Young Jedi befindet sich auf einem aufstrebenden Ast
Standard

Zitat:
Zitat von k1nGk0oL Beitrag anzeigen
Wahrscheinlich weil er dann $b, $c ,$d mit dem Wert '' übergibt und dafür kein entsprechender Datensatz existiert.
Hmm die Abfrage lautet ja
('$a' = '' OR a = '$a')
Das heißt, der Wert $a muss gar nicht in der Spalte a des Datensatzes existieren. Denn dann ist ja die Bedingung '$a' = '' wahr und die Bedingung a = '$a' muss es nicht mehr sein, damit der gesamte Ausdruck wahr ist.
__________________
http://tippsgegenlangeweile.de

Young Jedi ist offline  
Alt 24.01.2009, 22:41  
Neuer Benutzer
 
Registriert seit: 13.01.2009
Beiträge: 7
k1nGk0oL befindet sich auf einem aufstrebenden Ast
Standard

Ich will halt nach mehreren Sachen spezifisch suchen. Das heißt ich hab vier Suchfelder und will dann den Datensatz der mit $a und $c meinetwegen übereinstimmt ohne dabei $b und $d berücksichtigen zu müssen.
Man kann es bestimmt einfacher mit einer allgemeinen Suchanfrage machen, aber ich möchte es gerne so realisieren.

Und ich glaube falls a = '$a' und b = '' übergeben werden, sucht er einen Datensatz, wobei a = '$a' UND b = '' , allerdings steht in b ja was drin. Somit findet er keinen Datensatz.
k1nGk0oL ist offline  
Alt 25.01.2009, 11:18  
Erfahrener Benutzer
 
Benutzerbild von litterauspirna
 
Registriert seit: 24.04.2008
Beiträge: 3.172
PHP-Kenntnisse:
Anfänger
litterauspirna sorgt für eine eindrucksvolle Atmosphärelitterauspirna sorgt für eine eindrucksvolle Atmosphäre
litterauspirna eine Nachricht über ICQ schicken
Standard

Hallo.

Überdenke doch noch mal wie du suchen willst. Ein kleiner Tipp. Wenn du nach Strings suchen willst,dann markiere das Tabellen Feld als FULLTEXT und suche mit Match() Against.

Ansonsten wenn die Felder nach denen du suchen willst z.B. Datum, Kategorien dann markiere die als INDEX,das macht die Suche schneller.

Diese Sachen erst mal machen die Suche schneller und genauer.

Dan unterteile deine Suche nach verschiedenen Eingabemöglichkeiten,indem du dann auch deinen Sql Stringteil nach Where mehrmals in verschiedene Bedingungen schreibst.

z.B. so

PHP-Code:
if($bedingung1 == $kriterium1 && $bedingung2 == $kriterium2)
{
       
//hier einen Sql String nach Where
}
elseif(
$bedingung1 != $kriterium1 && $bedingung2 == $kriterium2)
{
      
//wieder Sql String nach Where nach anderer Anforderung

__________________
Aus dem Dynamo Lande kommen wir. Trinken immer reichlich kühles Bier. Und dann sind wir alle voll, die Stimmung ist so toll. Aus dem Dynamo Lande kommen wir.
http://www.lit-web.de
litterauspirna ist offline  
Alt 25.01.2009, 21:09  
Neuer Benutzer
 
Registriert seit: 13.01.2009
Beiträge: 7
k1nGk0oL befindet sich auf einem aufstrebenden Ast
Standard

Vielen Dank, die If-Abfragen haben mir sehr geholfen. Habe zwar gehofft, dass man auch in SQL eine ähnliche Wirkung erzielen kann. Aber letztendlich tun es die paar If-Abfragen auch.
k1nGk0oL 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
SuFu mit mehreren Eingabefeldern? binäri PHP Tipps 2008 10 06.06.2008 17:32
Array nach mehreren Feldern sortieren Marcel1 PHP Tipps 2008 4 04.06.2008 05:09
COUNT in mehreren Feldern mit unterschiedlichen Bedingungen ecomeback Datenbanken 6 10.02.2008 17:58
Suchfunktion mit JavaScript snboy2007 JavaScript, Ajax und mehr 2 31.10.2007 13:38
Abfrage: sortieren mit mehreren Feldern, ASC und DESC php_frage Datenbanken 3 29.04.2006 20:42
zählen in mehreren Feldern jens76 Datenbanken 4 01.11.2005 13:39
Suchfunktion für die Homepage? Was muss der Anfänger wissen? PHP Tipps 2005-2 1 11.10.2005 18:39
suchfunktion PHP Tipps 2005-2 3 27.09.2005 16:39
[Erledigt] Daten aus mehreren Tabellen holen Datenbanken 0 19.09.2005 17:14
MySql error -- Suchfunktion mit mehreren Begriffen PHP Tipps 2005 1 12.04.2005 21:06
Suchfunktion PHP Tipps 2005 8 03.04.2005 15:52
Suchfunktion nur für EINE Seite ! HTML, Usability und Barrierefreiheit 2 24.03.2005 18:42
Suche in mehreren Feldern PHP Tipps 2004-2 1 08.11.2004 09:31
Bloody n00b braucht Hilfe - Suchfunktion per PHP und MySQL PHP Tipps 2004 2 04.08.2004 22:28

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
suchfunktion felder, sql suchfunktion, php suche mit mehreren feldern, in verschiedenen feldernnach einem asdruck suchen mit sql, suchfunktion match against ajax, mehrere suchfelder leere felder sql

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