J'ai cette requête:Zend_Db_Select: Travailler avec JOIN de
SELECT
groups.name
categories.name,
categories.label
FROM
groups
JOIN
categories
ON
(categories.group1 = groups.id
OR
categories.group2 = groups.id)
AND
groups.label = :section
AND
categories.active = 1
Maintenant, voici mon join En utilisant Zend_Db_Select mais il me donne l'erreur de tableau
$select->from($dao, array('groups.name', 'categories.name', 'categories.label'))
->join(array('categories', 'categories.group1 = groups.id OR categories.group2 = groups.id'))
->where('groups.label = ?', $group)
->where('categories.active = 1');
Mon erreur:
Exception information:
Message: Select query cannot join with another table
Est-ce que quelqu'un sait ce que j'ai fait de mal?
MISE A JOUR/SOLUTION:
J'ai trouvé la solution à Eran Thanx. Je poste juste la solution ici au cas où quelqu'un d'autre serait coincé sur un problème comme celui-ci. La solution est:
$db = Zend_Registry::get('db');
$dao = new Default_Model_Db_CategoryDao('db');
$select = $dao->select();
$select->setIntegrityCheck(false)
->from(array('c' => 'categories'), array('name', 'label'))
->join(array('g' => 'groups'), 'c.group1 = g.id OR c.group2 = g.id', 'g.label')
->where('g.label = ?', $group)
->where('c.active = 1');
return $dao->fetchAll($select);
I ajouté -> setIntegrityCheck (false) et maintenant je reçois: Mysqli préparer erreur: Unknown column 'groups.name' dans 'liste des champs' –
N'utilisez pas le nom de la table dans le tableau de colonnes, il provient de l'objet Zend_Db_Table d'origine –