$order_no]; $codes = $this->app->db->name('ShopOrderItem')->where($map)->column('goods_code'); foreach (array_unique($codes) as $code) GoodsService::instance()->syncStock($code); return true; } /** * 绑定订单详情数据 * @param array $data * @return array * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\DbException * @throws \think\db\exception\ModelNotFoundException */ public function buildItemData(array &$data = []): array { // 关联发货信息 $nobs = array_unique(array_column($data, 'order_no')); $trucks = $this->app->db->name('ShopOrderSend')->whereIn('order_no', $nobs)->column('*', 'order_no'); foreach ($trucks as &$item) unset($item['id'], $item['uid'], $item['status'], $item['deleted'], $item['create_at']); // 关联订单商品 $query = $this->app->db->name('ShopOrderItem')->where(['status' => 1, 'deleted' => 0]); $items = $query->withoutField('id,uid,status,deleted,create_at')->whereIn('order_no', $nobs)->select()->toArray(); // 关联用户数据 $fields = 'username,phone,nickname,headimg,status'; UserService::instance()->buildByUid($data, 'uid', 'member', $fields); UserService::instance()->buildByUid($data, 'from', 'fromer', $fields); foreach ($data as &$vo) { $vo['sales'] = 0; $vo['truck'] = $trucks[$vo['order_no']] ?? []; $vo['items'] = []; foreach ($items as $item) if ($vo['order_no'] === $item['order_no']) { $vo['sales'] += $item['stock_sales']; $vo['items'][] = $item; } } return $data; } }