0

我正在寻找一种在 Symfony 1.4 中基于此 SQL 制作标准的方法:

SELECT item.position, 
CASE 
    WHEN item.position = 1 THEN item.position + 1
    WHEN item.position = 2 THEN item.position - 1
    ELSE item.position
END AS new_position
FROM item ORDER BY new_position ASC

我试图使用这篇文章中的示例,
但它没有帮助

make 很重要$criteria,因为它稍后会传递给渲染项目列表和排序项目的插件$criteria

WHEN条件只是示例,我将使用更复杂的条件。

4

2 回答 2

0

您可以在 Query.php 类中使用 php 开关来构建条件(由于您的问题显示了简化的示例,因此您的条件所需的开关可能要复杂得多):

//in YourModelQuery.php
public function addMyItemPositionCriteria($itemPosition) {
    //TODO: validate $itemPosition values as needed
    switch ($itemPosition) {
        case 1:
            return $this->add([$criteria see http://api.propelorm.org/1.6.8/ browse propel.runtime.query Criteria and ModelCriteria classes ]);
            break;
        case 2:
            return $this->add([$criteria here]);
            break;
        }
}

或者您可以类似地在您的 ModelPeer.php 类(或没有函数调用的操作类)中构建一个 $criteria 对象:

// in MyObjectPeerClass.php
public static function addMyItemPositionCriteria($itemPosition) {
    //TODO: validate $itemPosition values as needed
    $criteria = new Criteria;
    switch ($itemPosition) {
        case 1:
            return $criteria->add([$criteria see http://api.propelorm.org/1.6.8/ browse propel.runtime.query Criteria and ModelCriteria classes ]);
            break;
        case 2:
            return $criteria->add([$criteria here]);
            break;
        }
}

然后,您可以使用此标准:

//depending on context
// in ModelQuery.php call 
    $this->addMyItemPostion($itemPosition);
// call to model query
    ModelQuery::create()->addMyItemPosition($itemPosition)->find();
//in action or somewhere else (adding to previously defined $criteria)
    $new_criteria = MyObjectPeerClass::addMyItemPosition($itemPosition);
    $criteria->add($new_criteria);
于 2013-03-26T18:43:50.537 回答
0

您可以使用语句“withColumn”,然后自定义您的查询

->withColumn("CASE WHEN CLIENTE_ID = {$cliente->getId()} THEN 'Pontos Pessoais' ELSE 'Pontos de Equipe' END", 'descricao')

于 2019-12-16T13:07:45.033 回答