Fecshop 2016-09-21 09:20:21 7795次浏览 0条评论 2 2 0

通过PDO,默认出来的数据都是string类型,在Yii2的AR(Active Record)中,按照类型进行了数据转换,但是如果查询的时候使用了asArray(),则不会进行转换,也就是说

User::find()->asArray()->all()

FancyECommerce.com 原文地址:yii2 AR 结构进行数据类型转换的原理(PDO)

查询的结果,包括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()查询的时候,速度是最快的,但是要注意一下数据类型,适当的时候需要手动转换。

一个比较明显的使用遇到的问题就是,在查询结果使用 === 这种强相等判断的时候,通过asArray()查询出来的结果,需要进行数据进行类型转换,或者, 使用弱相等判断 ==

觉得很赞
    没有找到数据。
您需要登录后才可以评论。登录 | 立即注册