Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP/SQL] Problem z optymalizacją - uproszczeniem skryptu
oi.
post
Post #1





Grupa: Zarejestrowani
Postów: 145
Pomógł: 1
Dołączył: 12.07.2006

Ostrzeżenie: (10%)
X----


Witam, stworzyłem skrypt wyszukujący z bazy danych dane słowa, po ich wykryciu wykonuje wskazane przeze mnie czynności.
Kod:
  1. <?php
  2. $a="aaa";
  3. $b="bbb";
  4. $c="ccc";
  5. $d="ddd";
  6.  
  7. $pytanie = "SELECT * FROM ogl WHERE kategoria=1 AND
  8. ( tytul  LIKE '%$a%' or tytul  LIKE '%$b%' or tytul  LIKE '%$c%' or tytul  LIKE '%$d%'
  9. or tresc LIKE '%$a%' or tresc LIKE '%$b%' or tresc LIKE '%$c%' or tresc LIKE '%$d%')
  10. ORDER BY id DESC LIMIT 5";
  11. ?>


Skrypt działa poprawnie, ale jest dość mało rozwojowy, bo np teraz korzysta z 4 zmiennych które sprawdza w polu tytul oraz 4 w polu tresc.
Przez co zapytanie SQL robi się długie i mało czytelne. W przyszłości planuję rozbudować ten skryp do wyszukiwania większej ilości zmiennych i w tej postaci skryptu pogubię się.

Jak można to uprościć ?
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 8)
piotrooo89
post
Post #2


Newsman


Grupa: Moderatorzy
Postów: 4 005
Pomógł: 548
Dołączył: 7.04.2008
Skąd: Trzebinia/Kraków




fulltext search.
Go to the top of the page
+Quote Post
oi.
post
Post #3





Grupa: Zarejestrowani
Postów: 145
Pomógł: 1
Dołączył: 12.07.2006

Ostrzeżenie: (10%)
X----


Z tego co tam wyczytałem to
  1. haystack LIKE ('%word1%word2%')

u mnie przełożyłoby się na :
  1. haystack LIKE ('%w$ą%$b%$c%$d%')

o to chodzi?
Go to the top of the page
+Quote Post
piotrooo89
post
Post #4


Newsman


Grupa: Moderatorzy
Postów: 4 005
Pomógł: 548
Dołączył: 7.04.2008
Skąd: Trzebinia/Kraków




(IMG:http://forum.php.pl/style_emoticons/default/questionmark.gif) nie rozumiem? nie musisz stosować LIKE jak masz fulltext. MATCH i AGANIST tylko używasz + funkcje które podaje manual.
Go to the top of the page
+Quote Post
oi.
post
Post #5





Grupa: Zarejestrowani
Postów: 145
Pomógł: 1
Dołączył: 12.07.2006

Ostrzeżenie: (10%)
X----


Nie bardzo wiem jak to wdrożyć w moim przypadku.
Go to the top of the page
+Quote Post
Sword
post
Post #6





Grupa: Zarejestrowani
Postów: 15
Pomógł: 0
Dołączył: 17.12.2008

Ostrzeżenie: (0%)
-----


http://blog.kutar.pl/2008/05/wyszukiwanie-...deksy-fulltext/
z tym, że zauważyłem, żeby coś wyszukało to rekord musi zawierać więcej znaków tzn. np kilka zdań, nie wiem, ale u mnie nie działa gdy jest krótkie zdanie.
Go to the top of the page
+Quote Post
piotrooo89
post
Post #7


Newsman


Grupa: Moderatorzy
Postów: 4 005
Pomógł: 548
Dołączył: 7.04.2008
Skąd: Trzebinia/Kraków




  1. MATCH (tytul, tresc) AGANIST ('$a $b $c $d')


taki schemacik.
Go to the top of the page
+Quote Post
oi.
post
Post #8





Grupa: Zarejestrowani
Postów: 145
Pomógł: 1
Dołączył: 12.07.2006

Ostrzeżenie: (10%)
X----


  1. $pytanie = "SELECT * FROM ogl WHERE kategoria=26 AND ( MATCH (tytul, tresc) AGAINST ('$a $b $c $d') ) ORDER BY id DESC LIMIT 5 ";

Wyskakuje błąd Warning: mysql_fetch_array(): supplied argument is not a valid MySQL" title="Zobacz w manualu PHP" target="_manual
Podejrzewam że chodzi o te nagnieżdżone nawiasy.
PS poprawiłem literówkę AGANIST na AGAINST
Go to the top of the page
+Quote Post
erix
post
Post #9





Grupa: Moderatorzy
Postów: 15 467
Pomógł: 1451
Dołączył: 25.04.2005
Skąd: Szczebrzeszyn/Rzeszów




Wyrażenie w against również musi posiadać cudzysłowy.
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 24.08.2025 - 02:26