$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 { // 关联用户数据 $mids = array_unique(array_merge(array_column($data, 'uid'), array_column($data, 'from'))); $members = $this->app->db->name('DataUser')->whereIn('id', $mids)->column('*', 'id'); foreach ($members as &$user) { unset($user['token'], $user['tokenv'], $user['openid1'], $user['openid2']); unset($user['unionid'], $user['password'], $user['status'], $user['deleted']); } // 关联发货信息 $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(); foreach ($data as &$vo) { $vo['sales'] = 0; $vo['member'] = $members[$vo['uid']] ?? []; $vo['fromer'] = $members[$vo['from']] ?? []; $vo['truck'] = $trucks[$vo['order_no']] ?? []; $vo['items'] = []; foreach ($items as $item) { if ($vo['order_no'] === $item['order_no']) { $vo['items'][] = $item; $vo['sales'] += $item['stock_sales']; } } } return $data; } }