Php 推进连接行为
我这样做:Php 推进连接行为,php,mysql,symfony,join,propel,Php,Mysql,Symfony,Join,Propel,我这样做: $model = ProductQuery::create() ->filterById($id) ->joinLocale() ->joinProducer() ->joinCategory() ->joinFile() ->joinSeo() ->find(); 这将创建查询: SELECT Food_Prod
$model = ProductQuery::create()
->filterById($id)
->joinLocale()
->joinProducer()
->joinCategory()
->joinFile()
->joinSeo()
->find();
这将创建查询:
SELECT
Food_Product.id,
Food_Product.locale_id,
Food_Product.category_id,
Food_Product.producer_id,
Food_Product.file_id,
Food_Product.seo_id,
Food_Product.customer_id,
Food_Product.name,
Food_Product.description,
Food_Product.nutrient_unit,
Food_Product.ean,
Food_Product.top,
Food_Product.calls,
Food_Product.visible,
Food_Product.created_at,
Food_Product.updated_at,
Food_Product.created_by,
Food_Product.updated_by
FROM `Food_Product`
INNER JOIN `I18n_Locale` ON (Food_Product.locale_id=I18n_Locale.id)
LEFT JOIN `Food_Producer` ON (Food_Product.producer_id=Food_Producer.id)
INNER JOIN `System_Category` ON (Food_Product.category_id=System_Category.id)
LEFT JOIN `Media_File` ON (Food_Product.file_id=Media_File.id)
INNER JOIN `System_Seo` ON (Food_Product.seo_id=System_Seo.id)
WHERE Food_Product.id='1'
我只得到一个没有相关数据的产品实例。因此,如果我调用$product->getProducer()
,将有另一个数据库请求
如果我添加
->select('*'),
我不再得到实体实例,而是得到一个包含产品数据的数组。但同样,没有生产者、地区或类别数据。我注意到,->joinWith('producer')
。而不是->joinProducer()
就像一个符咒