采用laravel的chunkById段落查询方法,一次查询2K,然后批量入库,由于这个表没啥改动,可以直接查询后导入
遇到的问题是,查询后的数据属性是一个数组,要手动组装下才能直接入库,字段有点多,试想能不能直接拿到这个属性数据然后丢到数组里直接入库
查询出的数据是这样(推荐:《php视频教程》)
是私有属性
直接 (array)$value 后是这样
那么直接
$arrTemp['x00*x00attributes']应该就可以,试了下确实行
封装下:
public function getProtectedValue($obj, $name) { $array = (array)$obj; $prefix = chr(0).'*'.chr(0); return $array[$prefix.$name]; }
截图中x00对应的ASCII码为0,用chr将0的ASCII码转换为字符串,即chr(0)对应ASCII码为x00,然后拼接下*就OK
调整后的代码为
$arrTemp = $this->getProtectedValue($value, 'attributes');