在Yii的CActiveRecord中,我们如何返回属性已将数据类型设置为integer
请看下面的例子:在Yii的CActiveRecord中,我们如何返回属性已将数据类型设置为integer,yii,Yii,请看下面的例子: mysql> SELECT rowid, myset, myset+0 -> FROM set_test; +-------+-----------------------+---------+ | rowid | myset | myset+0 | +-------+-----------------------+---------+ | 1 | Sports |
mysql> SELECT rowid, myset, myset+0
-> FROM set_test;
+-------+-----------------------+---------+
| rowid | myset | myset+0 |
+-------+-----------------------+---------+
| 1 | Sports | 2 |
| 2 | Travel,Sports | 3 |
| 3 | Travel,Dancing | 5 |
| 4 | Travel,Sports | 3 |
| 5 | Travel,Sports,Dancing | 7 |
| 6 | Travel,Dancing | 5 |
| 7 | Sports | 2 |
| 8 | Travel,Dancing | 5 |
+-------+-----------------------+---------+
8 rows in set (0.00 sec)
对于Yii,使用CActiveRecord->myset
总是返回一个以逗号分隔的字符串。
如何像上面那样以
整数返回?您可以覆盖活动记录类中的getter方法或创建一个新方法
private _mysetInt = array('Sports' => 2, [...]);
function getMyset(){
$return = 0;
foreach(explode(',',$this->myset) AS $value) {
$return += $this->_mysetInt[$value];
};
return $return;
}
此外,获取这些整数值的方法应根据您的需要进行调整,上面的示例只是伪代码。对不起,myset+0
是db表的一列吗?不,myset是一列,myset+0只是转换为整数。:)