最近要导入一下数据,要把一个项目的部分数据导入到另一个项目中
采用laravel的chunkById段落查询方法,一次查询2K,然后批量入库,由于这个表没啥改动,可以直接查询后导入
遇到的问题是,查询后的数据属性是一个数组,要手动组装下才能直接入库,字段有点多,试想能不能直接拿到这个属性数据然后丢到数组里直接入库
查询出的数据是这样
是私有属性
直接 (array)$value 后是这样
那么直接
$arrTemp['x00*x00attributes']应该就可以,试了下确实行
不过直接用x00下标取应该会被打的,要处理下
封装后:
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');
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。