2010-10-24 5 views
2

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); 

Répondre

4

Vous utilisez un objet Zend_Db_Table_Select. Ceux-ci ont par défaut la vérification d'intégrité activée et ne peuvent pas sélectionner les données qui sont en dehors de leur table.

Vous pouvez le désactiver en ajoutant -> setIntegrityCheck (false) à l'objet select avant d'interroger avec.

Vous pouvez en lire davantage in the manual sous Sélectionner API -> Utilisation avancée

+0

I ajouté -> setIntegrityCheck (false) et maintenant je reçois: Mysqli préparer erreur: Unknown column 'groups.name' dans 'liste des champs' –

+0

N'utilisez pas le nom de la table dans le tableau de colonnes, il provient de l'objet Zend_Db_Table d'origine –