有没有办法将自定义查询添加到集合呈现的magento选择?

Fel*_*hur 2 collections magento

我有一个magento集合,如果我回显getSelect()函数,我得到一个像这样的查询:

   SELECT 
    `table1`.*,
    `table`.*,
    `table3.fieldy` AS 'fieldname'
  .....
  FROM ....
  WHERE....
Run Code Online (Sandbox Code Playgroud)

我想将此查询更改为以下内容:

   SELECT 
    `table1`.*,
    `table`.*,
    `table3.fieldy` AS 'fieldname',
     (SELECT col1, col2, (case when (action == 2 and state == 0) then 1 else 0 end) as state from tbl1)   AS 'fieldname2'
    ......
    FROM....
    WHERE....
Run Code Online (Sandbox Code Playgroud)

现在,例如,对于where子句,您可以使用以下方法向查询添加文本

productCollection->getSelect()->where('query text');
Run Code Online (Sandbox Code Playgroud)

但是如何将自定义查询文本添加到选择的第一部分?

非常感谢

Ser*_*gey 5

您可以使用Mage_Eav_Model_Entity_Collection_Abstract函数addExpressionAttributeToSelect将Subselect添加到查询中.
或者只需添加新的子选择字段以选择为:

$this->getSelect()->columns(array($alias => $fullExpression));
Run Code Online (Sandbox Code Playgroud)

注意:$fullExpression应该用引号括起来.