feat : order
This commit is contained in:
@@ -21,6 +21,7 @@ use Hyperf\Di\Annotation\Inject;
|
|||||||
use PhpAmqpLib\Message\AMQPMessage;
|
use PhpAmqpLib\Message\AMQPMessage;
|
||||||
use Psr\Container\ContainerExceptionInterface;
|
use Psr\Container\ContainerExceptionInterface;
|
||||||
use Psr\Container\NotFoundExceptionInterface;
|
use Psr\Container\NotFoundExceptionInterface;
|
||||||
|
use Throwable;
|
||||||
|
|
||||||
#[Consumer(exchange: 'OrderGoodStock', routingKey: 'OrderGoodStock', queue: 'OrderGoodStock.change', name: "OrderGoodStockConsumer", nums: 1)]
|
#[Consumer(exchange: 'OrderGoodStock', routingKey: 'OrderGoodStock', queue: 'OrderGoodStock.change', name: "OrderGoodStockConsumer", nums: 1)]
|
||||||
class OrderGoodStockConsumer extends ConsumerMessage
|
class OrderGoodStockConsumer extends ConsumerMessage
|
||||||
@@ -113,13 +114,22 @@ class OrderGoodStockConsumer extends ConsumerMessage
|
|||||||
return Result::ACK;
|
return Result::ACK;
|
||||||
}
|
}
|
||||||
|
|
||||||
$res = Db::table('sku')->update($this->updateArr);
|
$updateModel = new Sku();
|
||||||
if (!$res) {
|
try {
|
||||||
$this->log->debug('OrderGoodStockConsumer:error:UpdateSkuDataFail:'.json_encode($this->updateArr));
|
Db::beginTransaction();
|
||||||
return Result::ACK;
|
|
||||||
|
foreach (array_chunk($this->updateArr, 500) as $chunk) {
|
||||||
|
foreach ($chunk as $item) {
|
||||||
|
$updateModel->where('id',$item['id'])->update(array_diff_key($item, ['id' => null]));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->log->Debug('OrderGoodStockConsumer:'.json_encode($this->updateArr).':'.json_encode($res));
|
Db::commit(); // 确认提交
|
||||||
|
} catch (Throwable $e) {
|
||||||
|
Db::rollBack(); // 出现异常时回滚
|
||||||
|
$this->log->debug('OrderGoodStockConsumer:error:UpdateSkuDataFail:msg:'.$e->getMessage().':data:'.json_encode($this->updateArr));
|
||||||
|
return Result::ACK;
|
||||||
|
}
|
||||||
|
|
||||||
return Result::ACK;
|
return Result::ACK;
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
|
|||||||
Reference in New Issue
Block a user