yii mysql 查询 类型转换_yii2 数据库查询结果字段类型的问题

yii2数据库查询默认返回的为AR对象,此时字段类型与数据库的基本相符,但如果使用 asArray 以数组的方式返回时,默认字段类型全都是 string,如果这样 json_encode 后返回给 App端的话,会被 Android/IOS这些强类型语言端的工程师们喷死,php会再次被推向风口。

原因是 pdo 在 yii2盛行时还不够完善,一些特性是后期加进来的,比如我们急切需要的返回的结果数据类型与数据库一致。

return [

'class' => 'yii\db\Connection',

'dsn' => 'mysql:host=localhost;dbname=yii2basic',

'username' => 'root',

'password' => '123456',

'charset' => 'utf8',

'tablePrefix' => 'yii_',

'attributes' => [

PDO::ATTR_STRINGIFY_FETCHES => false,

PDO::ATTR_EMULATE_PREPARES => false,

]

// Schema cache options (for production environment)

//'enableSchemaCache' => true,

//'schemaCacheDuration' => 60,

//'schemaCache' => 'cache',

];

yii2 在数据库组件配置中添加attributes的两项配置即可。

未配置时:

// AR 对象的 attributes

array (size=7)

'id' => string '1' (length=1)

'account' => string 'big_cat' (length=7)

'password' => string 'e10adc3949ba59abbe56e057f20f883e' (length=32)

'age' => int 29

'created_at' => string '2019-05-16 11:23:26' (length=19)

'updated_at' => string '2019-05-16 11:23:26' (length=19)

'status' => int 1

// asArray

array (size=7)

'id' => string '1' (length=1)

'account' => string 'big_cat' (length=7)

'password' => string 'e10adc3949ba59abbe56e057f20f883e' (length=32)

'age' => string '29' (length=2)

'created_at' => string '2019-05-16 11:23:26' (length=19)

'updated_at' => string '2019-05-16 11:23:26' (length=19)

'status' => string '1' (length=1)

配置后

// AR 对象的 attributes

array (size=7)

'id' => string '1' (length=1)

'account' => string 'big_cat' (length=7)

'password' => string 'e10adc3949ba59abbe56e057f20f883e' (length=32)

'age' => int 29

'created_at' => string '2019-05-16 11:23:26' (length=19)

'updated_at' => string '2019-05-16 11:23:26' (length=19)

'status' => int 1

// asArray

array (size=7)

'id' => int 1

'account' => string 'big_cat' (length=7)

'password' => string 'e10adc3949ba59abbe56e057f20f883e' (length=32)

'age' => int 29

'created_at' => string '2019-05-16 11:23:26' (length=19)

'updated_at' => string '2019-05-16 11:23:26' (length=19)

'status' => int 1

可以发现:

1、AR 对象默认就能将字段类型与数据库中尽可能的一致,但id还是string类型。

2、以数组的方式返回结果时,yii2默认将所有字段都以string方式处理,通过配置pdo属性能完全的将字段类型同数据库一致。

配置pdo属性后查询 AR 对象的话id还是没有同数据库字段类型一致,但数组方式查询则完全一致了。

而且数组查询方式更节省内存,性能更高(yii2其实始终以数组模式查询,如果不使用asArray模式,会对查询到的数组结果集结合对应的Model进行映射成相应的AR对象,即asArray其实是关闭了数组映射至AR对象的步骤,参照),我们为App提供数据时本身就是要提供一些数据标量,没必要查询数据对象,所以接口返回数据时都应该以asArray的方式查询,且配置PDO的属性以便保持数据字段类型的一致性,避免对接上的混乱。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值