php.de

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

 
 
LinkBack Themen-Optionen Thema bewerten
Alt 22.04.2008, 12:27  
Benutzer
 
Registriert seit: 09.04.2008
Beiträge: 60
keinplanvonnix befindet sich auf einem aufstrebenden Ast
Standard komplizierte SQL-Abfrage

Tabelle hat unter anderem folgende Felder: ueberschrift (varchar), kurztext (text), langtext (text), von (date)... und einige mehr

Problem: Es soll in den o.g. Feldern gesucht werden ob 3 Suchworte vorhanden sind, wobei jedes der Suchworte mind. einmal vorkommen muss.
Die Suchworte können enthalten: Ziffern, Buchstaben und Bindstrich (für Datumsformat)

meine Lösungsansätze:
Variante 1
PHP-Code:
        $sql "SELECT *,DATE_FORMAT(von, '%d.%m.%Y') AS von_format FROM texte WHERE 
        (ueberschrift LIKE '%"
.$suchworte[0]."%' OR ueberschrift LIKE '%".$suchworte[1]."%' OR ueberschrift LIKE '%".$suchworte[2]."%') 
        AND (kurztext LIKE '%"
.$suchworte[0]."%' OR kurztext LIKE '%".$suchworte[1]."%' OR kurztext LIKE '%".$suchworte[2]."%') 
        AND (text LIKE '%"
.$suchworte[0]."%' OR text LIKE '%".$suchworte[1]."%' OR text LIKE '%".$suchworte[2]."%') 
        AND (von LIKE '%"
.$suchworte[0]."%' OR von LIKE '%".$suchworte[1]."%' OR von LIKE '%".$suchworte[2]."%') 
        ORDER BY von DESC"

dise Abfrage funktioniert natürlich nicht weil er dann in jedem der 4 Felder mind. ein Suchwort braucht und wenn ich die ANDs mit OR ersetze dann entspricht das ja auch nicht dem Problem weil er dann jeden Datensatz findet, in dem mind. 1 und nicht alle 3 Suchworte vorhanden sind.

Variante 2 - Subqueries
Da ist leider das Problemchen dass ich von Subqueries keine Ahnung habe und die Infos im Netz dürftig sind. So habe ich in 2 Std keinerlei Infos gefunden wie oft ich IN verwenden kann, innerhalb einer Abfrage.
meine Idee ist ein solches Konstrukt:
PHP-Code:
        $sql "SELECT *,DATE_FORMAT(von, '%d.%m.%Y') AS von_format 
        FROM texte 
        WHERE ueberschrift LIKE '%"
.$suchworte[0]."%' OR ueberschrift LIKE '%".$suchworte[1]."%' OR ueberschrift LIKE '%".$suchworte[2]."%' 
        IN 
            (SELECT *,DATE_FORMAT(von, '%d.%m.%Y') AS von_format 
            FROM texte 
            WHERE kurztext LIKE '%"
.$suchworte[0]."%' OR kurztext LIKE '%".$suchworte[1]."%' OR kurztext LIKE '%".$suchworte[2]."%'
            IN
                (SELECT *,DATE_FORMAT(von, '%d.%m.%Y') AS von_format 
                FROM texte 
                WHERE text LIKE '%"
.$suchworte[0]."%' OR text LIKE '%".$suchworte[1]."%' OR text LIKE '%".$suchworte[2]."%' 
                IN
                     (SELECT *,DATE_FORMAT(von, '%d.%m.%Y') AS von_format 
                     FROM texte 
                     WHERE von LIKE '%"
.$suchworte[0]."%' OR von LIKE '%".$suchworte[1]."%' OR von LIKE '%".$suchworte[2]."%' 
        )))ORDER BY von DESC"

Fehlermeldung:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'IN (SELECT *,DATE_FORMAT(von, '%d.%m.%Y') AS von_format FROM texte ' at line 4


Irgendwie dreht sich jetzt zwar alles im Kopf aber es kommt nix raus. Über einen Wink mit einem grossen Zaunspfahl wäre ich sehr dankbar.

Danke schon im voraus und guten Hunger
keinplanvonnix ist offline  
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 23.04.2008, 08:24  
Benutzer
 
Registriert seit: 09.04.2008
Beiträge: 60
keinplanvonnix befindet sich auf einem aufstrebenden Ast
Standard

drüber geschlafen und immer noch im irrgarten looking for zaunspfahl
keinplanvonnix ist offline  
Alt 23.04.2008, 10:00  
Benutzer
 
Registriert seit: 09.04.2008
Beiträge: 60
keinplanvonnix befindet sich auf einem aufstrebenden Ast
Standard

ok erstmal eine notlösung gefunden.
um die eleganz kümmern "wir" uns nächste woche


PHP-Code:
### wenn ueberschrift suchwort[0] enthält dann prüfe in allen 3 feldern ob das 2.suchwort auch vorhanden ist und flals das auch zutrifft suche noch in allen 3 feldern nach dem 3.suchwort
        
$erg=mysql_query("SELECT *,DATE_FORMAT(von, '%d.%m.%Y') AS von_format 
        FROM texte         
        WHERE (ueberschrift LIKE '%"
.$suchworte['0']."%' AND (ueberschrift LIKE '%".$suchworte['1']."%' OR kurztext LIKE '%".$suchworte['1']."%' OR text LIKE '%".$suchworte['1']."%') AND (ueberschrift LIKE '%".$suchworte['2']."%' OR kurztext LIKE '%".$suchworte['2']."%' OR text LIKE '%".$suchworte['2']."%')) 
        OR (kurztext LIKE '%"
.$suchworte['0']."%' AND (ueberschrift LIKE '%".$suchworte['1']."%' OR kurztext LIKE '%".$suchworte['1']."%' OR text LIKE '%".$suchworte['1']."%') AND (ueberschrift LIKE '%".$suchworte['2']."%' OR kurztext LIKE '%".$suchworte['2']."%' OR text LIKE '%".$suchworte['2']."%')) 
        OR (text LIKE '%"
.$suchworte['0']."%' AND (ueberschrift LIKE '%".$suchworte['1']."%' OR kurztext LIKE '%".$suchworte['1']."%' OR text LIKE '%".$suchworte['1']."%') AND (ueberschrift LIKE '%".$suchworte['2']."%' OR kurztext LIKE '%".$suchworte['2']."%' OR text LIKE '%".$suchworte['2']."%')) 
        ORDER BY von DESC"
); 
keinplanvonnix ist offline  
Alt 23.04.2008, 15:42  
Moderator
 
Benutzerbild von cycap
 
Registriert seit: 13.02.2008
Beiträge: 6.816
PHP-Kenntnisse:
Fortgeschritten
cycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nettcycap ist einfach richtig nett
Standard

Kleiner Tipp: http://www.php.de/mysql/973-tool-sql-formatter.html
cycap 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
komplizierte mysql abfrage php_frage PHP Tipps 2007 5 28.12.2005 17:55
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
komplizierte Abfrage aus 2 Tabellen gleichzeitig Datenbanken 2 22.06.2005 02:54
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
2 Tabellen 1 Abfrage nilsfeld Datenbanken 6 11.08.2004 11:18
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

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
komplizierte sql-abfrage, date_format sql, sql date_format, komplizierte sql abfragen, komplizierte sql abfrage, sql abfrage text, sql abfrage date_format, komplizierteste sql abfrage, sql abfrage mit text, sql abfrage überschrift, mysql soundex, sehr komplizierte sql abfrage, sql problem afrage komplizierte frage, schriftgröße in sql select, php sql like, php sql such anfrage, like in sql abfragen, date_format() sql, abfragen überschrift, datenbank abfrage text beinhaltet

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