0

我正在尝试通过 CActiveRecord 生成并执行以下 sql:

SELECT * FROM `bucket` `t` 
WHERE bkt_user = unhex('A4FF2131E00C4696837689FCAAAC7DD2');

我想出了这个:

$uuid = 'A4FF2131E00C4696837689FCAAAC7DD2';
$criteria = new CDbCriteria();
$expression = new CDbExpression(
                    'unhex(:value)', 
                    array(':value'=>$uuid,));
$criteria->addCondition("bkt_user = :exp");
$criteria->params = array(':exp' => $expression);
$buckets = Bucket::model()->findAll($criteria);

代码执行时没有错误或异常,但未按预期返回结果。稍微调试一下,发现上面的代码片段生成了以下 sql:

SELECT * FROM `xpg_bucket` `t` WHERE bkt_user = :exp

和 AFAIK 只有一个CDbCommandBuilder::bindValue:exp必然的unhex(:value)。没有为:value. 这发生在CDbCommandBuilder::createFindCommand. CDbCommandBuilder::createInsertCommand, 另一方面似乎照顾了一个值本身是 aCDbExpression并生成了适当的bindValue's

CDbExpression's文档包含:

* CDbExpression is mainly used in {@link CActiveRecord} as attribute values.
* When inserting or updating a {@link CActiveRecord}, attribute values of      
* type CDbExpression will be directly put into the corresponding SQL statement
* without escaping.  

这是否意味着 CDbExpression 不能与 findAll() 中的 CDbCriteria 一起使用?如果是,有什么替代方案?

4

1 回答 1

1

实际上,事实证明,马戏团并不是必需的。以下适用于findAll

$criteria->addCondition('bkt_user = unhex(:value)');
$criteria->params = array(':value'=>'665730BDEDA7489383E2519DB5DE6D60');
$buckets = Bucket::model()->findAll($criteria);

请注意,同样不适用于addorupdate操作。

于 2013-10-27T09:37:14.643 回答