Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [ZendFramework]wyciąganie z kilku tabel ->joinLeft();
Forum PHP.pl > Forum > PHP > Frameworki
szmerak
Witam

Mam problem z selectem, a mianowicie jak wyciągnąć z 2 różnych tabel dane używając selecta?

  1. $db = $this->_db;
  2. $select = $db->select()
  3. ->from('job_offerts', array('offert_title'))
  4. ->joinLeft('country', 'country.id = job_offerts.offert_cat_id')
  5. ->where('offert_premium = 2')
  6. ->order('offert_added DESC')
  7. ->limit(12);
  8. $offerts = $db->fetchAll($select);
  9. $this->view->offerts = $offerts;


Chodzi mi o coś takiego select job_offerts.title, country.cat_name ...


Zacząłem dopiero uczyć się frameworka tak więc proszę o wyrozumiałość tongue.gif
ze4lot
  1. Example #12 Example of the join() method
  2.  
  3. // Build this query:
  4. // SELECT p."product_id", p."product_name", l.*
  5. // FROM "products" AS p JOIN "line_items" AS l
  6. // ON p.product_id = l.product_id
  7.  
  8. $select = $db->select()
  9. ->from(array('p' => 'products'),
  10. array('product_id', 'product_name'))
  11. ->join(array('l' => 'line_items'),
  12. 'p.product_id = l.product_id');
  13.  

źródło: http://framework.zend.com/manual/en/zend.db.select.html

zwróć uwagę na metody from oraz join - definujesz sobie wszystko na tablicach na zasadzie czysto SQLowej np. 'nazwa_tabeli AS tabela' tylko trochu inaczej to wygląda, a dokumentacja chętnie Ci wszystko wyjaśni
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.