handleCxData.php 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446
  1. <?php
  2. namespace app\command;
  3. use think\console\Command;
  4. use think\console\Input;
  5. use think\console\Output;
  6. use think\Exception;
  7. use think\facade\Db;
  8. //将cfp_caixiao_data里面的数据,分别处理到cfp_qrd_info,cfp_cgd_info(若未对账),或者cfp_caixiao_wait(已对账)
  9. class handleCxData extends command
  10. {
  11. private $interval = 15000 * 60;//执行间隔,单位:分(每次同步前5分钟的数据)
  12. protected function configure()
  13. {
  14. parent::configure(); // TODO: Change the autogenerated stub
  15. $this->setName('handleCxData')->setDescription('处理中间表的采销数据');
  16. }
  17. protected function execute(Input $input, Output $output)
  18. {
  19. $date = date('Y-m-d H:i:s');
  20. Db::startTrans();
  21. $result = Db::name('caixiao_data')
  22. // ->json(["data"])
  23. ->withAttr("data",function ($v){return json_decode(str_replace(array("\r\n", "\r", "\n"), '', $v),true);})
  24. ->where("status",1)
  25. ->where("addtime",">=",date("Y-m-d H:i:s",strtotime(time()-1800)))
  26. ->lock(true)
  27. ->findOrEmpty();
  28. if ($result) {
  29. try {
  30. $data = $result['data']??[];
  31. $qrd_insert_data = $wait_insert_data = $cgd_insert_data = [];
  32. $data['cat_name'] = is_array($data['cat_name'])?$data['cat_name']: json_decode($data['cat_name'],
  33. true);
  34. if ($result['order_type'] == 1) {
  35. $data['total_price'] = $data['total_price'] - $data['th_fee'] - $data['diff_fee'];
  36. $exitReport= Db::name("report_code")->where('qrdNo', $data['orderCode'])->findOrEmpty();
  37. $repostinsert= [
  38. "qrdNo"=>$data['orderCode'],
  39. "seller_id"=>$data['apply_id'],
  40. "seller"=>$data['apply_name'],
  41. "customerName"=>$data['customer_name'],
  42. "customerNo"=>$data['customer_code'],
  43. "companyNo"=>$data['supplierNo'],
  44. "companyName"=>$data['supplier_name'],
  45. "cgdNo"=>$data['cgdNo'],
  46. ];
  47. if(empty($exitReport)) Db::name("report_code")->insert($repostinsert);
  48. else Db::name("report_code")->where($exitReport)->update($repostinsert);
  49. $exists_qrd = Db::name('qrd_info')
  50. ->whereIn('sequenceNo', $data['orderCode'])
  51. ->field('id,status')->findOrEmpty();
  52. $all_branch = Db::name('customer_info')
  53. ->whereIn('companyNo', $data['customer_code'])
  54. ->column('branch,parent', 'companyNo');
  55. //已存在
  56. if (!empty($exists_qrd)) {
  57. if ($exists_qrd['status'] == 0) {
  58. $report= [
  59. "qrdNo"=>$data['orderCode'],
  60. "seller_id"=>$data['apply_id'],
  61. "seller"=>$data['apply_name'],
  62. "customerName"=>$data['customer_name'],
  63. "customerNo"=>$data['customer_code'],
  64. "companyNo"=>$data['supplierNo'],
  65. "companyName"=>$data['supplier_name'],
  66. "cgdNo"=>$data['cgdNo'],
  67. ];
  68. $re= Db::name('qrd_info')
  69. ->where('id', $exists_qrd['id'])
  70. ->update([
  71. 'name' => $data['orderCode'],//确认单名称,
  72. 'sequenceNo' => $data['orderCode'],//确认单编号,
  73. 'ownerName' => $data['apply_name'],//销售员,
  74. 'ownerid' => $data['apply_id'],//销售员id,
  75. 'department' => $data['depart'],//部门,
  76. 'createdTime' => $data['addtime'],//销售单创建时间,
  77. 'qrdType' => $data['order_type'],//销售单类型,
  78. 'qrdSource' => $data['order_source'],//销售单来源,
  79. 'companyNo' => $data['supplierNo'],//业务企业编号,
  80. 'companyName' => $data['supplier_name'],//业务企业名称,
  81. 'customerNo' => $data['customer_code'],//客户编号,
  82. 'customerName' => $data['customer_name'],//客户名称,
  83. 'poCode' => $data['poNo'],//po编号,
  84. 'platName' => $data['platform_id'],//平台名称,
  85. 'workCode' => $data['workNo'],//业务编号,
  86. 'zxCode' => $data['zxNo'],//咨询单编号,
  87. 'goodNo' => $data['good_code'],//商品编号,
  88. 'goodName' => $data['good_name'],//商品名称,
  89. 'goodBrand' => $data['brand'],//商品品牌,
  90. 'firstCat' => $data['cat_name'][0]['cat_name']??"",//一级分类,
  91. 'secCat' => $data['cat_name'][1]['cat_name']??"",//二级分类,
  92. 'thirdCat' => $data['cat_name'][2]['cat_name']??"",//三级分类,
  93. 'catInfo' => json_encode($data['cat_name'],JSON_UNESCAPED_UNICODE),//分类详情,
  94. 'fundCode' => $data['cat_name'][2]['fund_code']??"",//核算编码,
  95. 'goodMaterial' => '',//商品材质,
  96. 'goodUnit' => $data['unit'],//商品单位,
  97. 'goodDesc' => $data['cost_desc'],//工艺说明,
  98. 'goodType' => $data['good_type'],//商品类型,
  99. 'goodModel' => '',//商品型号,
  100. 'isStock' => $data['is_stock'],//是否库存品,
  101. 'metalsType' => $data['noble_metal'],//贵金属种类,
  102. 'weight' => $data['good_weight'],//商品重量,
  103. 'goldPrice' => $data['gold_price'],//贵金属单价,
  104. 'deliveryDay' => $data['delivery_day'],//物流天数,
  105. 'workDay' => $data['lead_time'],//工期,
  106. 'tax' => $data['tax'],//税率,
  107. 'goodNum' => $data['good_num'],//销售数量,
  108. 'goodPrice' => $data['sale_price'],//产品单价,
  109. 'totalPrice' => $data['total_price'],//货款总额,
  110. 'total_origin_price' => $data['total_origin_price'],//成本总额,
  111. 'sendNum' => $data['send_num'],//已发货数量,
  112. 'wsendNum' => $data['wsend_num'],//未发货数量,
  113. 'apay_fee' => 0,//已付款,
  114. 'pay_fee' => 0,//付款中
  115. 'wpay_fee' => $data['total_price'],//未付款,
  116. 'inv_fee' => 0,//回票中
  117. 'ainv_fee' => 0,//已开票,
  118. 'winv_fee' => $data['total_price'],//未开票,
  119. 'is_diff' => $data['is_diff'],//是否有工差,
  120. 'sendType' => $data['send_type'],//发货方式,
  121. 'sendStatus' => $data['send_status'],//发货状态,
  122. 'pay_status' =>$data['total_price']==0?3:1,//收款状态,1未付,2部分,3完结
  123. 'inv_status' => $data['total_price']==0?3:1,//开票状态,,1未付,2部分,3完结
  124. 'remark' =>"",//备注,
  125. 'cxCode' => $data['oldCode']??"",//备注,
  126. 'invtime' => null,
  127. 'paytime' => null,
  128. 'diff_weight' => $data['diff_weight'],//工差重量,
  129. 'diff_fee' => $data['diff_fee'],//工差金额,
  130. 'area' => $data['customer_name'],//公司,
  131. 'customerAttr' =>$all_branch[$data['customer_code']]['parent'] ?? '',//客户属性,
  132. 'branch' => $all_branch[$data['customer_code']]['branch'] ?? '',//分公司,从客户表中查
  133. 'cgdNo' => $data['cgdNo'],//采购单号,
  134. 'thNum' => $data['th_num'],//退货数量,
  135. 'th_fee' => $data['th_fee'],//退货金额,
  136. 'pay_source' => $data['pay_source']??"",//支付渠道,
  137. 'is_del' => 0,//是否删除,
  138. 'addtime' => $date,
  139. 'updatetime' => $date,
  140. 'inv_tag' => 0,//开票标签,
  141. 'pay_tag' => 0,//回款标签,
  142. 'inv_tag_fee' => 0,//开票票标签金额,
  143. 'pay_tag_fee' => 0,//回款标签金额,
  144. ]);
  145. } else {
  146. $wait_insert_data=[
  147. "order_type"=>$result['order_type'],
  148. "data"=>json_encode($result['data'],JSON_UNESCAPED_UNICODE),
  149. "orderCode"=>$data['orderCode'],
  150. "status"=>1,
  151. ];
  152. }
  153. } else {
  154. //新增
  155. $qrd_insert_data[] = [
  156. 'name' => $data['orderCode'],//确认单名称,
  157. 'sequenceNo' => $data['orderCode'],//确认单编号,
  158. 'ownerName' => $data['apply_name'],//销售员,
  159. 'ownerid' => $data['apply_id'],//销售员id,
  160. 'department' => $data['depart'],//部门,
  161. 'createdTime' => $data['addtime'],//销售单创建时间,
  162. 'qrdType' => $data['order_type'],//销售单类型,
  163. 'qrdSource' => $data['order_source'],//销售单来源,
  164. 'companyNo' => $data['supplierNo'],//业务企业编号,
  165. 'companyName' => $data['supplier_name'],//业务企业名称,
  166. 'customerNo' => $data['customer_code'],//客户编号,
  167. 'customerName' => $data['customer_name'],//客户名称,
  168. 'poCode' => $data['poNo'],//po编号,
  169. 'platName' => $data['platform_id'],//平台名称,
  170. 'workCode' => $data['workNo'],//业务编号,
  171. 'zxCode' => $data['zxNo'],//咨询单编号,
  172. 'goodNo' => $data['good_code'],//商品编号,
  173. 'goodName' => $data['good_name'],//商品名称,
  174. 'goodBrand' => $data['brand'],//商品品牌,
  175. 'firstCat' => $data['cat_name'][0]['cat_name']??"",//一级分类,
  176. 'secCat' => $data['cat_name'][1]['cat_name']??"",//二级分类,
  177. 'thirdCat' => $data['cat_name'][2]['cat_name']??"",//三级分类,
  178. 'catInfo' => json_encode($data['cat_name'],JSON_UNESCAPED_UNICODE),//分类详情,
  179. 'fundCode' => $data['cat_name'][2]['fund_code']??"",//核算编码,
  180. 'goodMaterial' => '',//商品材质,
  181. 'goodUnit' => $data['unit'],//商品单位,
  182. 'goodDesc' => $data['cost_desc'],//工艺说明,
  183. 'goodType' => $data['good_type'],//商品类型,
  184. 'goodModel' => '',//商品型号,
  185. 'isStock' => $data['is_stock'],//是否库存品,
  186. 'metalsType' => $data['noble_metal'],//贵金属种类,
  187. 'weight' => $data['good_weight'],//商品重量,
  188. 'goldPrice' => $data['gold_price'],//贵金属单价,
  189. 'deliveryDay' => $data['delivery_day'],//物流天数,
  190. 'workDay' => $data['lead_time'],//工期,
  191. 'tax' => $data['tax'],//税率,
  192. 'goodNum' => $data['good_num'],//销售数量,
  193. 'goodPrice' => $data['sale_price'],//产品单价,
  194. 'totalPrice' => $data['total_price'],//货款总额,
  195. 'total_origin_price' => $data['total_origin_price'],//成本总额,
  196. 'sendNum' => $data['send_num'],//已发货数量,
  197. 'wsendNum' => $data['wsend_num'],//未发货数量,
  198. 'apay_fee' => 0,//已付款,
  199. 'pay_fee' => 0,//付款中
  200. 'wpay_fee' => $data['total_price'],//未付款,
  201. 'inv_fee' => 0,//回票中
  202. 'ainv_fee' => 0,//已开票,
  203. 'winv_fee' => $data['total_price'],//未开票,
  204. 'is_diff' => $data['is_diff'],//是否有工差,
  205. 'sendType' => $data['send_type'],//发货方式,
  206. 'sendStatus' => $data['send_status'],//发货状态,
  207. 'pay_status' => $data['total_price']==0?3: 1,//收款状态,1未付,2部分,3完结
  208. 'inv_status' => $data['total_price']==0?3: 1,//开票状态,,1未付,2部分,3完结
  209. 'remark' => "",//备注,
  210. 'cxCode' => $data['oldCode']??"",//备注,
  211. 'invtime' => null,
  212. 'paytime' => null,
  213. 'diff_weight' => $data['diff_weight'],//工差重量,
  214. 'diff_fee' => $data['diff_fee'],//工差金额,
  215. 'area' => $data['customer_name'],//公司,
  216. 'customerAttr' => $all_branch[$data['customer_code']]['parent'],//客户属性,
  217. 'branch' => $all_branch[$data['customer_code']]['branch'] ?? '',//分公司,从客户表中查
  218. 'cgdNo' => $data['cgdNo'],//采购单号,
  219. 'thNum' => $data['th_num'],//退货数量,
  220. 'th_fee' => $data['th_fee'],//退货金额,
  221. 'pay_source' => $data['pay_source']??"",//支付渠道,
  222. 'is_del' => 0,//是否删除,
  223. 'addtime' => $date,
  224. 'updatetime' => $date,
  225. 'inv_tag' => 0,//开票标签,
  226. 'pay_tag' => 0,//回款标签,
  227. 'inv_tag_fee' => 0,//开票票标签金额,
  228. 'pay_tag_fee' => 0,//回款标签金额,
  229. ];
  230. }
  231. } else {
  232. //已存在
  233. $data['total_fee'] = $data['total_fee'] - $data['th_fee'] - $data['diff_fee'];
  234. $exitReport= Db::name("report_code")->where('cgdNo', $data['cgdNo'])->findOrEmpty();
  235. $repostinsert= [
  236. "qrdNo"=>$data['qrdNo'],
  237. "cgder_id"=>$data['cgder_id'],
  238. "cgder"=>$data['cgder'],
  239. "supplierName"=>$data['supplier_name'],
  240. "supplierNo"=>$data['supplierNo'],
  241. "companyNo"=>$data['companyNo'],
  242. "companyName"=>$data['companyName'],
  243. "cgdNo"=>$data['cgdNo'],
  244. ];
  245. if(empty($exitReport)) Db::name("report_code")->insert($repostinsert);
  246. else Db::name("report_code")->where($exitReport)->update($repostinsert);
  247. $exists_cgd = Db::name('cgd_info')
  248. ->whereIn('sequenceNo', $data['cgdNo'])
  249. ->field('id,status')->findOrEmpty();
  250. if (!empty($exists_cgd )) {
  251. //未对账,更新
  252. if ($exists_cgd['status'] == 0) {
  253. Db::name('cgd_info')
  254. ->where('id', $exists_cgd['id'])
  255. ->update([
  256. 'name' => $data['cgdNo'],//采购单名称',
  257. 'sequenceNo' => $data['cgdNo'],//采购单编号',
  258. 'ownerName' => $data['cgder'],//采购员名称',
  259. 'ownerid' => $data['cgder_id'],//采购员id',
  260. 'department' => $data['depart'],//部门名称',
  261. 'createdTime' => $data['addtime'],//订单创建时间',
  262. 'cgdType' => $data['order_type'],//采购单类型',
  263. 'cgdSource' => $data['order_source'],//采购单来源',
  264. 'companyNo' => $data['companyNo'],//业务公司编号',
  265. 'companyName' => $data['companyName'],//业务公司',
  266. 'cgdTime' => $data['addtime'],//采购下单时间',
  267. 'bkCode' => $data['bkcode'],//备库单编号',
  268. 'qrdCode' => $data['qrdNo'],//确认单编号',
  269. 'goodNo' => $data['spuCode'],//商品编号',
  270. 'goodName' => $data['good_name'],//商品名称',
  271. 'goodType' => $data['good_type'],//商品类型',
  272. 'goodBrand' => $data['brand'],//商品品牌',
  273. 'goodModel' => '',//商品型号',
  274. 'firstCat' => $data['cat_name'][0]['cat_name'],//商品一级分类',
  275. 'secCat' => $data['cat_name'][1]['cat_name'],//二级分类',
  276. 'thirdCat' => $data['cat_name'][2]['cat_name'],//三级分类',
  277. 'catInfo' => json_encode($data['cat_name'],JSON_UNESCAPED_UNICODE),//分类明细',
  278. 'fundCode' => $data['cat_name'][2]['fund_code'],//NOT NULL,
  279. 'goodMaterial' => '',//商品材质',
  280. 'goodUnit' => $data['unit'],//商品单位',
  281. 'goodDesc' => $data['cost_desc'],//工艺说明',
  282. 'metalsType' => $data['noble_metal'],//贵金属种类',
  283. 'weight' => $data['weight'],//商品重量',
  284. 'goldPrice' => $data['gold_price'],//贵金属实时金价',
  285. 'is_diff' => $data['is_diff'],//是否有工差',
  286. 'deliveryDay' => $data['delivery_day'],//物流天数',
  287. 'workDay' => $data['lead_time'],//产品工期',
  288. 'tax' => $data['tax'],//税点',
  289. 'barePrice' => $data['nake_fee'],//裸价',
  290. 'markPrice' => $data['mark_fee'],//加标费',
  291. 'packPrice' => $data['pakage_fee'],//包装费',
  292. 'certPrice' => $data['cert_fee'],//证书费',
  293. 'openPrice' => $data['open_fee'],//开模费',
  294. 'costPrice' => $data['teach_fee'],//工艺费',
  295. 'deliveryPrice' => $data['delivery_fee'],//物流费',
  296. 'goodPrice' => $data['good_price'],//成本合计/单价',
  297. 'isStock' => $data['is_stock'],//是否库存品',
  298. 'goodNum' => $data['good_num'],//下单数量',
  299. 'totalPrice' => $data['total_fee'],//采购总货款',
  300. 'supplierNo' => $data['supplierNo'],//供应商编号',
  301. 'supplierName' => $data['supplier_name'],//供应商名称',
  302. 'apay_fee' => 0,//已付款金额',
  303. 'wpay_fee' => $data['total_fee'],//未付款金额',
  304. 'ainv_fee' => 0,//已开票金额',
  305. 'winv_fee' => $data['total_fee'],//未开票金额',
  306. 'sendType' => $data['send_type'],//发货方式',
  307. 'bkCreater' => $data['bkcreater'],//备库申请人',
  308. 'sendStatus' => $data['send_status'],//发货状态',
  309. 'wsendNum' => $data['wsend_num'],//未发货数量',
  310. 'sendNum' => $data['send_num'],//已发货数量',
  311. 'wareHouse' => $data['wsm_code'],//仓库名称',
  312. 'wsmCode' => $data['wsm_code'],//仓库编号',
  313. 'remark' => '',//备注',
  314. 'cxCode' => $data['oldCode']??"",//备注,
  315. 'pay_status' => $data['total_fee']==0?3: 1,//付款情况',
  316. 'inv_status' => $data['total_fee']==0?3: 1,//开票情况',
  317. 'diff_weight' => $data['diff_weight'],//工差重量',
  318. 'diff_fee' => $data['diff_fee'],//工差金额',
  319. 'thNum' => $data['th_num'],//退货数量',
  320. 'th_fee' => $data['th_fee'],//退货金额',
  321. 'check_rate' => '',//修正后的税率',
  322. 'is_del' => 0,
  323. 'addtime' => $date,
  324. 'updatetime' => $date,
  325. ]);
  326. } else {
  327. $wait_insert_data=[
  328. "order_type"=>$result['order_type'],
  329. "data"=>json_encode($result['data'],JSON_UNESCAPED_UNICODE),
  330. "orderCode"=>$data['cgdNo'],
  331. "status"=>1,
  332. ];
  333. }
  334. } else {
  335. //新增
  336. $cgd_insert_data[] = [
  337. 'name' => $data['cgdNo'],//采购单名称',
  338. 'sequenceNo' => $data['cgdNo'],//采购单编号',
  339. 'ownerName' => $data['cgder'],//采购员名称',
  340. 'ownerid' => $data['cgder_id'],//采购员id',
  341. 'department' => $data['depart'],//部门名称',
  342. 'createdTime' => $data['addtime'],//订单创建时间',
  343. 'cgdType' => $data['order_type'],//采购单类型',
  344. 'cgdSource' => $data['order_source'],//采购单来源',
  345. 'companyNo' => $data['companyNo'],//业务公司编号',
  346. 'companyName' => $data['companyName'],//业务公司',
  347. 'cgdTime' => $data['addtime'],//采购下单时间',
  348. 'bkCode' => $data['bkcode'],//备库单编号',
  349. 'qrdCode' => $data['qrdNo'],//确认单编号',
  350. 'goodNo' => $data['spuCode'],//商品编号',
  351. 'goodName' => $data['good_name'],//商品名称',
  352. 'goodType' => $data['good_type'],//商品类型',
  353. 'goodBrand' => $data['brand'],//商品品牌',
  354. 'goodModel' => '',//商品型号',
  355. 'firstCat' => $data['cat_name'][0]['cat_name']??"",//商品一级分类',
  356. 'secCat' => $data['cat_name'][1]['cat_name'],//二级分类',
  357. 'thirdCat' => $data['cat_name'][2]['cat_name'],//三级分类',
  358. 'catInfo' => json_encode($data['cat_name'],JSON_UNESCAPED_UNICODE),//分类明细',
  359. 'fundCode' => $data['cat_name'][2]['fund_code'],//NOT NULL,
  360. 'goodMaterial' => '',//商品材质',
  361. 'goodUnit' => $data['unit'],//商品单位',
  362. 'goodDesc' => $data['cost_desc'],//工艺说明',
  363. 'metalsType' => $data['noble_metal'],//贵金属种类',
  364. 'weight' => $data['weight'],//商品重量',
  365. 'goldPrice' => $data['gold_price'],//贵金属实时金价',
  366. 'is_diff' => $data['is_diff'],//是否有工差',
  367. 'deliveryDay' => $data['delivery_day'],//物流天数',
  368. 'workDay' => $data['lead_time'],//产品工期',
  369. 'tax' => $data['tax'],//税点',
  370. 'barePrice' => $data['nake_fee'],//裸价',
  371. 'markPrice' => $data['mark_fee'],//加标费',
  372. 'packPrice' => $data['pakage_fee'],//包装费',
  373. 'certPrice' => $data['cert_fee'],//证书费',
  374. 'openPrice' => $data['open_fee'],//开模费',
  375. 'costPrice' => $data['teach_fee'],//工艺费',
  376. 'deliveryPrice' => $data['delivery_fee'],//物流费',
  377. 'goodPrice' => $data['good_price'],//成本合计/单价',
  378. 'isStock' => $data['is_stock'],//是否库存品',
  379. 'goodNum' => $data['good_num'],//下单数量',
  380. 'totalPrice' => $data['total_fee'],//采购总货款',
  381. 'supplierNo' => $data['supplierNo'],//供应商编号',
  382. 'supplierName' => $data['supplier_name'],//供应商名称',
  383. 'apay_fee' => 0,//已付款金额',
  384. 'wpay_fee' => $data['total_fee'],//未付款金额',
  385. 'ainv_fee' => 0,//已开票金额',
  386. 'winv_fee' => $data['total_fee'],//未开票金额',
  387. 'sendType' => $data['send_type'],//发货方式',
  388. 'bkCreater' => $data['bkcreater'],//备库申请人',
  389. 'sendStatus' => $data['send_status'],//发货状态',
  390. 'wsendNum' => $data['wsend_num'],//未发货数量',
  391. 'sendNum' => $data['send_num'],//已发货数量',
  392. 'wareHouse' => $data['wsm_code'],//仓库名称',
  393. 'wsmCode' => $data['wsm_code'],//仓库编号',
  394. 'remark' => '',//备注',
  395. 'pay_status' =>$data['total_fee']==0?3: 1,//付款情况',
  396. 'inv_status' =>$data['total_fee']==0?3: 1,//开票情况',
  397. 'diff_weight' => $data['diff_weight'],//工差重量',
  398. 'diff_fee' => $data['diff_fee'],//工差金额',
  399. 'thNum' => $data['th_num'],//退货数量',
  400. 'th_fee' => $data['th_fee'],//退货金额',
  401. 'check_rate' => '',//修正后的税率',
  402. 'cxCode' => $data['oldCode']??"",//备注,
  403. 'is_del' => 0,
  404. 'addtime' => $date,
  405. 'updatetime' => $date,
  406. ];
  407. }
  408. }
  409. if ($qrd_insert_data) Db::name('qrd_info')->insertAll($qrd_insert_data);
  410. if ($cgd_insert_data) Db::name('cgd_info')->insertAll($cgd_insert_data);
  411. if ($wait_insert_data) Db::name('caixiao_wait')->insert($wait_insert_data);
  412. Db::name("caixiao_data")->where('uniqkey',$result['uniqkey'])->update(['status'=>0]);
  413. Db::commit();
  414. $output->writeln('处理成功');
  415. } catch (Exception $exception) {
  416. Db::rollback();
  417. $output->writeln($exception->getMessage());
  418. }
  419. }
  420. Db::rollback();
  421. }
  422. }