Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [zend] select i where - jak wykonać zapytanie z LIKE ?
nieraczek
post 26.10.2008, 08:11:18
Post #1





Grupa: Zarejestrowani
Postów: 405
Pomógł: 6
Dołączył: 12.01.2007

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


Chcę wykonać zapytanie takie:

  1. <?php
  2. query("SELECT * FROM obrazy WHERE tytul LIKE '%$wyrazenie%'");
  3. ?>


Jednak z uwagi na to, że taka metoda nie jest bezpieczna a mi nie chce się sprawdzać danych jakie wprowadził użytkownik muszę użyć funkcji ZF select() sad.gif

I oczywiście nie działa mi to:
  1. <?php
  2. $select->from('obrazy')->where('tytul = ?', '%$wyrazenie%');
  3. ?>


ani to:
  1. <?php
  2. $select->from('obrazy')->where('tytul = ?', '$wyrazenie');
  3. ?>


dopiero jak zamiast '$wyrazenie' podam PEŁNY tytuł to mi wyszuka, ale to nie jest dobra metoda wyszukiwania bo trzeba znać cały tytuł, a co w przypadku jak zna się tylko fragment ? A na stronie dokumentacji ZF http://framework.zend.com/manual/en/zend.db.select.html nie pokazali jak coś takiego zrobić.
Go to the top of the page
+Quote Post
LBO
post 26.10.2008, 08:15:08
Post #2





Grupa: Zarejestrowani
Postów: 1 415
Pomógł: 117
Dołączył: 7.09.2005
Skąd: Warszawa

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


Cytat(nieraczek @ 26.10.2008, 09:11:18 ) *
  1. <?php
  2. $select->from('obrazy')->where('tytul = ?', '%$wyrazenie%');
  3. ?>


hmmm, a nie powinna być tak?

  1. <?php
  2. $select->from('obrazy')->where('tytul LIKE ?', "%$wyrazenie%");
  3. ?>
Go to the top of the page
+Quote Post
nieraczek
post 26.10.2008, 08:51:44
Post #3





Grupa: Zarejestrowani
Postów: 405
Pomógł: 6
Dołączył: 12.01.2007

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


Niestety też nie działa sad.gif
Go to the top of the page
+Quote Post
thm
post 26.10.2008, 08:56:48
Post #4





Grupa: Zarejestrowani
Postów: 52
Pomógł: 10
Dołączył: 6.10.2008
Skąd: Lublin

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


  1. ->where('tytul like "%'.$wyrazenie.'%"');

albo
  1. ->where('tytul like "%?%"', $wyrazenie);
Go to the top of the page
+Quote Post
nieraczek
post 26.10.2008, 09:08:53
Post #5





Grupa: Zarejestrowani
Postów: 405
Pomógł: 6
Dołączył: 12.01.2007

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


Działa:
  1. <?php
  2. ->where('tytul like "%'.$wyrazenie.'%"');
  3. ?>



Nie działa:
  1. <?php
  2. ->where('tytul like "%?%"', $wyrazenie);
  3. ?>



Mogliby w dokumentacji o tym napisać, ale ta ich dokumentacja jest kiepska, mało kiedy można tam znaleźć to czego się szuka. :/

Dziwne są te ich funkcje, ale dobrze, że przynajmniej jak się tak pisze nie trzeba dbać o kontrolę danych wprowadzanych przez użytkownika smile.gif

Ten post edytował nieraczek 26.10.2008, 09:10:51
Go to the top of the page
+Quote Post

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

 



RSS Wersja Lo-Fi Aktualny czas: 31.07.2025 - 07:53