我正在尝试通过 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 一起使用?如果是,有什么替代方案?