通过PDO,默认出来的数据都是string类型,在Yii2的AR(Active Record)中,按照类型进行了数据转换,但是如果查询的时候使用了asArray(),则不会进行转换,也就是说
User::find()->asArray()->all()
查询的结果,包括id在内的所有结果,都是字符串类型
User::find()->all() ,返回的是对象数组,结果会进行类型转换
ActiveRecord转换的原理为下面:
yii\db\ActiveRecord
public static function populateRecord($record, $row) { $columns = static::getTableSchema()->columns; foreach ($row as $name => $value) { if (isset($columns[$name])) { $row[$name] = $columns[$name]->phpTypecast($value); } } parent::populateRecord($record, $row); }
通过上面的方法进行了类型的转换,也就是phpTypecast方法。
如果查询的时候加上了asArray(),则不会进行类型转换,出来的数据都是String
譬如代码:
$data = \fecadmin\models\AdminMicroRoleBrand::find()->asArray() ->where([ 'in','role_id',$micro_role_arr ])->all();
出来的是数据都是字符串
如果按照下面的代码,查询出来的对象里面的属性都是相应的数据库的类型:
$data = \fecadmin\models\AdminMicroRoleBrand::find() ->where([ 'in','role_id',$micro_role_arr ])->all();
所以,在加入asArray()查询的时候,速度是最快的,但是要注意一下数据类型,适当的时候需要手动转换。