Wie diese Abfrage mit Lehre übersetzen?
-
25-09-2019 - |
Frage
Ich versuche, eine benutzerdefinierte Abfrage zu generieren (Ich bin für eine Website über eine Suchmaschine zu entwickeln).
Dies ist te Abfrage zu übersetzen:
SELECT * FROM `offre_habitation`
WHERE `id_type_offre` = 2
AND `id_nature_offre` = 1
AND (`nb_pieces` = 2 or `nb_pieces` = 1 or `nb_pieces` = 3 or `nb_pieces` = 4)
AND (`id_secteur`=1 OR `id_secteur` = 2 or id_secteur = 3)
AND `surface_habitable` > 90
AND `prix` > 700
Könnten Sie mir bitte helfen?
Lösung
Nicht getestet, aber so etwas wie dies sollte es tun:
$q = Doctrine_Query::create()
->select('o.*')
->from('offre_habitation o')
->where('o.id_type_offre = ?', 2)
->andWhere('o.id_nature_offre = ?', 1)
->andWhereIn('o.nb_pieces', array(1, 2, 3, 4))
->andWhereIn('o.id_secteur', array(1, 2, 3))
->andWhere('o.surface_habitable > ?', 90)
->andWhere('o.prix > ?', 700);
// Test:
echo $q->getSqlQuery();
... verwendet das macht die Tatsache, dass zum Beispiel:
AND (`id_secteur`=1 OR `id_secteur` = 2 or id_secteur = 3)
... ist das gleiche wie:
AND `id_secteur` IN (1, 2, 3)
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow