采用laravel的chunkById段落查询方法,一次查询2K,然后批量入库,由于这个表没啥改动,可以直接查询后导入
遇到的问题是,查询后的数据属性是一个数组,要手动组装下才能直接入库,字段有点多,试想能不能直接拿到这个属性数据然后丢到数组里直接入库
查询出的数据是这样
是私有属性
直接 (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');
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论(0)