最近要导入一下数据,要把一个项目的部分数据导入到另一个项目中

采用laravel的chunkById段落查询方法,一次查询2K,然后批量入库,由于这个表没啥改动,可以直接查询后导入

遇到的问题是,查询后的数据属性是一个数组,要手动组装下才能直接入库,字段有点多,试想能不能直接拿到这个属性数据然后丢到数组里直接入库

查询出的数据是这样
image.png
image.png
是私有属性

直接 (array)$value 后是这样
image.png

那么直接
$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');

LinAt
10 声望0 粉丝