UNION и NOT IN Mysql Работа с Zend Framework - PullRequest
0 голосов
/ 23 октября 2010

Мне нужно выполнить следующий запрос mysql в Zend, я не эксперт по Zend Framework

SELECT  `optionride`.`featureoption_id`,
`optionride`.`featureoptionride_id`,`foption`.`featureoptionblock_id`,

`foption`.`labelname`,`optionride`.`value` FROM 
`engine4_ride_featureoptionrides` AS `optionride` 
LEFT JOIN `engine4_ride_featureoptions` AS `foption` 
ON foption.featureoption_id = optionride.featureoption_id 
WHERE (optionride.ride_id = '1' ) AND (foption.featureoptiontab_id= '2' )

UNION

SELECT `foption`.`featureoption_id`,  null as    
`featureoptionride_id`,`foption`.`featureoptionblock_id`,
`foption`.`labelname`,null as `value` FROM `engine4_ride_featureoptions` AS `foption`
WHERE (foption.featureoptiontab_id= '2' ) AND `foption`.`featureoption_id` NOT IN
(
   SELECT `optionride`.`featureoptionride_id` FROM `engine4_ride_featureoptionrides`   
   AS `optionride` 
   LEFT JOIN `engine4_ride_featureoptions` AS `foption` ON 
   foption.featureoption_id   =      optionride.featureoption_id 
  WHERE (optionride.ride_id = '1' ) AND (foption.featureoptiontab_id= '2' )
 )

Кто-нибудь может мне помочь, пожалуйста.

1 Ответ

0 голосов
/ 29 октября 2010

Вы можете поместить все свои запросы asis в $ db-> fetch ().

Также вы можете использовать $ db-> select () -> union (массив ($ sql1, $sql2)) , где $ sql1 , $ sql2 может быть $ db-> select () или строка ( "select)... ").

Для NOT IN вы можете использовать $ db-> where ('someField NOT IN (?)', Array ()) ;

...