GluFinishedProductWarehousing.php 55 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use think\db\exception\DataNotFoundException;
  5. use think\db\exception\ModelNotFoundException;
  6. use think\exception\DbException;
  7. use think\Db;
  8. /**
  9. * 糊盒成品入仓维护接口
  10. */
  11. class GluFinishedProductWarehousing extends Api
  12. {
  13. protected $noNeedLogin = ['*'];
  14. protected $noNeedRight = ['*'];
  15. /**
  16. * 首页
  17. *糊盒成品入仓测试
  18. */
  19. public function index()
  20. {
  21. $this->success('请求成功');
  22. }
  23. /**
  24. * 侧边栏
  25. * @ApiMethod (GET)
  26. */
  27. public function getTab()
  28. {
  29. //get请求
  30. if(!$this->request->isGet()){
  31. $this->error('请求方式错误');
  32. }
  33. $rows = db('糊盒成品入仓')
  34. ->field('LEFT(Sys_rq, 10) as date, COUNT(*) as counts')
  35. ->group('date')
  36. ->order('UniqId desc')
  37. ->limit(50)
  38. ->select();
  39. $num = db('糊盒成品入仓')
  40. ->where('Sys_rq','>=',$rows[count($rows)-1]['date'])
  41. ->count();
  42. $arr = db('糊盒成品入仓')
  43. ->field('LEFT(Sys_rq, 10) as date, rtrim(sys_id) as sys_id, COUNT(*) as count')
  44. ->where('Sys_rq','>=',$rows[count($rows)-1]['date'])
  45. ->group('date, sys_id')
  46. ->limit($num)
  47. ->select();
  48. foreach($rows as $key=>$value){
  49. $rows[$key]['sys'] = [];
  50. foreach($arr as $k=>$v){
  51. if($value['date'] == $v['date']){
  52. unset($v['date']);
  53. array_push($rows[$key]['sys'],$v);
  54. unset($arr[$k]);
  55. }
  56. }
  57. $rows[$key]['date'] = str_replace('-', '.', $rows[$key]['date']);
  58. }
  59. $this->success('成功',$rows);
  60. }
  61. /**
  62. * 侧边栏
  63. * @ApiMethod (GET)
  64. */
  65. public function getTabByGdbh()
  66. {
  67. //get请求
  68. if(!$this->request->isGet()){
  69. $this->error('请求方式错误');
  70. }
  71. $num = db('糊盒成品入仓')->count();
  72. $rows = db('糊盒成品入仓')
  73. ->field('jjcp_gdbh, rtrim(jjcp_cpdh) as jjcp_cpdh, LEFT(Sys_rq, 10) as Sys_rq')
  74. ->order('Sys_rq desc')
  75. ->limit($num)
  76. ->select();
  77. $num = db('工单_基本资料')->count();
  78. $arr = db('工单_基本资料')
  79. ->limit($num)
  80. ->column('CONCAT(Gd_gdbh, "-", rtrim(Gd_cpdh)) AS gdcp, CONCAT(rtrim(Gd_khdh), " 【", rtrim(Gd_khmc)) AS kh');
  81. $data = [];
  82. foreach ($rows as $value) {
  83. $key = $value['jjcp_gdbh'].'-'.$value['jjcp_cpdh'];
  84. if (isset($arr[$key]) && !isset($data[$arr[$key]])) {
  85. $data[$arr[$key]] = $value['Sys_rq'];
  86. }
  87. }
  88. // 对键进行升序排序
  89. uksort($data, function($a, $b) use ($data) {
  90. if ($data[$a] == $data[$b]) {
  91. return ($a > $b) ? 1 : -1; // 在值相同的情况下,根据键进行升序排列
  92. }
  93. return ($data[$a] < $data[$b]) ? 1 : -1;
  94. });
  95. $this->success('成功',$data);
  96. }
  97. /**
  98. * 列表
  99. * @ApiMethod (GET)
  100. * @param string $date 时间
  101. * @param string $sys_id 用户
  102. */
  103. public function getList()
  104. {
  105. // 验证请求方式
  106. if (!$this->request->isGet()) {
  107. $this->error('请求方式错误');
  108. }
  109. $req = $this->request->param();
  110. if (!isset($req['date'])) {
  111. $this->error('参数缺失');
  112. }
  113. // 设置分页参数,默认值
  114. $page = isset($req['page']) && !empty($req['page']) ? intval($req['page']) : 1;
  115. $limit = isset($req['limit']) && !empty($req['limit']) ? intval($req['limit']) : 20;
  116. // 构建查询条件
  117. if (strpos($req['date'], '-')) {
  118. $where = ['c.Sys_rq' => ['like', $req['date'] . '%']];
  119. $option = ['Sys_rq' => ['like', $req['date'] . '%']];
  120. } else {
  121. $where = [];
  122. $option = [];
  123. }
  124. if (isset($req['sys_id']) && !empty($req['sys_id'])) {
  125. $where['c.Sys_id'] = ['LIKE', $req['sys_id'] . '%'];
  126. $option['Sys_id'] = ['LIKE', $req['sys_id'] . '%'];
  127. }
  128. // 获取总数
  129. $total = db('糊盒成品入仓')->where($option)->count();
  130. // 查询数据(带分页)
  131. $rows = db('糊盒成品入仓')->alias('c')
  132. ->field('rtrim(c.入仓类型) as 入仓类型, rtrim(c.仓库编号) as 仓库编号, rtrim(c.仓库名称) as 仓库名称,
  133. rtrim(c.jjcp_num) as jjcp_num, c.jjcp_gdbh,
  134. c.jjcp_yjno, c.jjcp_sl, g.订单数量, rtrim(c.jjcp_dw) as jjcp_dw, LEFT(c.jjcp_sj, 10) as jjcp_sj,
  135. rtrim(c.jjcp_smb) as jjcp_smb, rtrim(c.jjcp_cpdh) as jjcp_cpdh, rtrim(c.jjcp_cpmc) as jjcp_cpmc,
  136. rtrim(c.成品编码) as 成品编码, rtrim(c.成品名称) as 成品名称,
  137. rtrim(c.客户料号) as 客户料号, rtrim(c.jjcp_desc) as jjcp_desc, LEFT(c.成品编码,'.config('product_code_digit').') as 客户编号, rtrim(g.Gd_客户名称) as Gd_客户名称,
  138. rtrim(c.机型备注) as 机型备注, rtrim(c.Sys_id) as Sys_id, c.Sys_rq, c.Mod_rq, c.UniqId')
  139. ->where($where)
  140. ->join('工单_基本资料 g', 'g.Gd_gdbh=c.jjcp_gdbh AND g.行号 = c.jjcp_yjno AND g.Gd_cpdh=c.jjcp_cpdh')
  141. ->order('c.UniqId desc')
  142. ->limit(($page - 1) * $limit, $limit)
  143. ->select();
  144. // 处理数据
  145. foreach ($rows as $key => $value) {
  146. $row = db('糊盒成品入仓')
  147. ->field('LEFT(Sys_rq, 10) as Sys_rq,jjcp_sl')
  148. ->where(['jjcp_gdbh' => $value['jjcp_gdbh'], 'jjcp_cpdh' => $value['jjcp_cpdh']])
  149. ->order('Sys_rq desc')
  150. ->select();
  151. $rows[$key]['jjcp_sls'] = 0;
  152. foreach ($row as $k => $v) {
  153. $rows[$key]['jjcp_sls'] += $v['jjcp_sl'];
  154. }
  155. if ($value['订单数量'] != 0) {
  156. $rows[$key]['完成率'] = number_format($rows[$key]['jjcp_sls'] / $value['订单数量'] / 100, 2);
  157. } else {
  158. $rows[$key]['完成率'] = '';
  159. }
  160. $rows[$key]['订单数量'] = floatval($value['订单数量'] * 10000);
  161. $rows[$key]['最近入仓日期'] = $row[0]['Sys_rq'];
  162. $rows[$key]['Mod_rq'] = $value['Mod_rq'] == '1900-01-01 00:00:00' ? '' : $value['Mod_rq'];
  163. }
  164. $data = [
  165. 'total' => $total,
  166. 'rows' => $rows,
  167. ];
  168. $this->success('成功', $data);
  169. }
  170. /**
  171. * 定位
  172. * @ApiMethod (GET)
  173. * @param string $gdbh 工单编号
  174. * @param string $cpmc 产品名称
  175. * @param string $page 页码
  176. * @param string $limit 数量
  177. */
  178. public function locate()
  179. {
  180. //get请求
  181. if(!$this->request->isGet()){
  182. $this->error('请求方式错误');
  183. }
  184. $req = $this->request->param();
  185. $page = 1;
  186. $limit = 15;
  187. if (isset($req['page']) && !empty($req['page'])) $page = $req['page'];
  188. if (isset($req['limit']) && !empty($req['limit'])) $limit = $req['limit'];
  189. if (isset($req['gdbh']) && !empty($req['gdbh'])){
  190. $where = ['c.jjcp_gdbh'=>[ 'like', '%' . $req['gdbh'] . '%']];
  191. $option = ['jjcp_gdbh'=>[ 'like', '%' . $req['gdbh'] . '%']];
  192. //客户编号
  193. $rows = db('糊盒成品入仓')->alias('c')
  194. ->field('rtrim(c.入仓类型) as 入仓类型, rtrim(c.仓库编号) as 仓库编号, rtrim(c.仓库名称) as 仓库名称,
  195. rtrim(c.jjcp_num) as jjcp_num, c.jjcp_gdbh,
  196. c.jjcp_yjno, c.jjcp_sl, g.订单数量, rtrim(c.jjcp_dw) as jjcp_dw, LEFT(c.jjcp_sj, 10) as jjcp_sj,
  197. rtrim(c.jjcp_smb) as jjcp_smb, rtrim(y.yj_Yjdh) as yj_Yjdh, rtrim(y.yj_yjmc) as yj_yjmc,
  198. rtrim(c.jjcp_cpdh) as jjcp_cpdh, rtrim(c.jjcp_cpmc) as jjcp_cpmc,
  199. rtrim(c.客户料号) as 客户料号, rtrim(c.jjcp_desc) as jjcp_desc, LEFT(c.成品编码,'.config('product_code_digit').') as 客户编号, rtrim(g.Gd_客户名称) as Gd_客户名称,
  200. rtrim(c.机型备注) as 机型备注, rtrim(c.Sys_id) as Sys_id, c.Sys_rq, c.Mod_rq, c.UniqId')
  201. ->where($where)
  202. ->where('y.yj_Yjno=c.jjcp_yjno')
  203. ->where('g.Gd_cpdh=c.jjcp_cpdh')
  204. ->join('工单_基本资料 g','g.Gd_gdbh=c.jjcp_gdbh')
  205. ->join('工单_印件资料 y','y.Yj_Gdbh=c.jjcp_gdbh')
  206. ->order('c.UniqId desc')
  207. ->page($page,$limit)
  208. ->select();
  209. $total = db('糊盒成品入仓')->where($option)->count();
  210. }else{
  211. if (isset($req['cpmc']) && !empty($req['cpmc'])){
  212. //查询工单表
  213. $gd = db('工单_基本资料')
  214. ->where('Gd_cpmc', 'LIKE', '%'.$req['cpmc'].'%')
  215. ->column('Gd_gdbh');
  216. $where = ['c.jjcp_gdbh'=>['in', $gd]];
  217. $option = ['jjcp_gdbh'=>['in', $gd]];
  218. //客户编号
  219. $rows = db('糊盒成品入仓')->alias('c')
  220. ->field('rtrim(c.入仓类型) as 入仓类型, rtrim(c.仓库编号) as 仓库编号, rtrim(c.仓库名称) as 仓库名称,
  221. rtrim(c.jjcp_num) as jjcp_num, c.jjcp_gdbh,
  222. c.jjcp_yjno, c.jjcp_sl, g.订单数量, rtrim(c.jjcp_dw) as jjcp_dw, LEFT(c.jjcp_sj, 10) as jjcp_sj,
  223. rtrim(c.jjcp_smb) as jjcp_smb, rtrim(y.yj_Yjdh) as yj_Yjdh, rtrim(y.yj_yjmc) as yj_yjmc,
  224. rtrim(c.jjcp_cpdh) as jjcp_cpdh, rtrim(c.jjcp_cpmc) as jjcp_cpmc,
  225. rtrim(c.客户料号) as 客户料号, rtrim(c.jjcp_desc) as jjcp_desc, LEFT(c.成品编码,'.config('product_code_digit').') as 客户编号, rtrim(g.Gd_客户名称) as Gd_客户名称,
  226. rtrim(c.机型备注) as 机型备注, rtrim(c.Sys_id) as Sys_id, c.Sys_rq, c.Mod_rq, c.UniqId')
  227. ->where($where)
  228. ->where('y.yj_Yjno=c.jjcp_yjno')
  229. ->where('g.Gd_cpdh=c.jjcp_cpdh')
  230. ->join('工单_基本资料 g','g.Gd_gdbh=c.jjcp_gdbh')
  231. ->join('工单_印件资料 y','y.Yj_Gdbh=c.jjcp_gdbh')
  232. ->order('c.UniqId desc')
  233. ->page($page,$limit)
  234. ->select();
  235. $total = db('糊盒成品入仓')->where($option)->count();
  236. }else{
  237. $this->error('参数错误');
  238. }
  239. }
  240. foreach ($rows as $key=>$value) {
  241. $row = db('糊盒成品入仓')
  242. ->field('LEFT(Sys_rq, 10) as Sys_rq,jjcp_sl')
  243. ->where(['jjcp_gdbh'=>$value['jjcp_gdbh'], 'jjcp_cpdh'=>$value['jjcp_cpdh']])
  244. ->order('Sys_rq desc')
  245. ->select();
  246. $rows[$key]['jjcp_sls'] = 0;
  247. foreach ($row as $k=>$v) {
  248. $rows[$key]['jjcp_sls'] += $v['jjcp_sl'];
  249. }
  250. if ($value['订单数量']!=0){
  251. $rows[$key]['完成率'] = number_format($rows[$key]['jjcp_sls']/$value['订单数量']/100,2);
  252. }else{
  253. $rows[$key]['完成率'] = '';
  254. }
  255. $rows[$key]['订单数量'] = floatval($value['订单数量']*10000);
  256. $rows[$key]['最近入仓日期'] = $row[0]['Sys_rq'];
  257. $rows[$key]['Mod_rq'] = $value['Mod_rq']=='1900-01-01 00:00:00' ? '' :$value['Mod_rq'];
  258. }
  259. $data = [
  260. 'total' => $total,
  261. 'rows' => $rows,
  262. ];
  263. $this->success('成功',$data);
  264. }
  265. /**
  266. * 获取信息
  267. * @ApiMethod (GET)
  268. * @param string $UniqId UniqId
  269. */
  270. public function getInfo()
  271. {
  272. //get请求
  273. if(!$this->request->isGet()){
  274. $this->error('请求方式错误');
  275. }
  276. $req = $this->request->param();
  277. if (isset($req['UniqId']) && !empty($req['UniqId'])){
  278. $UniqId = $req['UniqId'];
  279. }else{
  280. $this->error('参数错误');
  281. }
  282. //客户编号
  283. $rows = db('糊盒成品入仓')->alias('c')
  284. ->field('rtrim(c.入仓类型) as 入仓类型, rtrim(c.仓库编号) as 仓库编号, rtrim(c.仓库名称) as 仓库名称,
  285. rtrim(c.jjcp_num) as jjcp_num,
  286. c.jjcp_gdbh, c.jjcp_yjno, rtrim(c.订单编号) as 订单编号,
  287. rtrim(c.jjcp_cpdh) as jjcp_cpdh, rtrim(c.jjcp_cpmc) as jjcp_cpmc,
  288. rtrim(c.成品编码) as 成品编码, rtrim(c.成品名称) as 成品名称,
  289. rtrim(c.客户料号) as 客户料号,
  290. rtrim(c.jjcp_smb) as jjcp_smb, LEFT(c.jjcp_sj, 10) as jjcp_sj,
  291. c.jjcp_sl, rtrim(c.jjcp_dw) as jjcp_dw,
  292. g.订单数量*10000 as 订单数量, rtrim(c.机型备注) as 机型备注, rtrim(c.jjcp_desc) as jjcp_desc,
  293. rtrim(c.Sys_id) as Sys_id, c.Sys_rq, c.Mod_rq, c.UniqId')
  294. ->where('c.UniqId',$UniqId)
  295. ->where('g.Gd_cpdh=c.jjcp_cpdh')
  296. ->join('工单_基本资料 g','g.Gd_gdbh=c.jjcp_gdbh')
  297. ->find();
  298. $rows['jjcp_sls'] = db('糊盒成品入仓')
  299. ->where(['jjcp_gdbh'=>$rows['jjcp_gdbh'], 'jjcp_cpdh'=>$rows['jjcp_cpdh']])
  300. ->sum('jjcp_sl');
  301. $this->success('成功',$rows);
  302. }
  303. /**
  304. * 获取仓库信息
  305. * @ApiMethod (GET)
  306. * @param string keyword 关键词
  307. */
  308. public function getCk()
  309. {
  310. //get请求
  311. if(!$this->request->isGet()){
  312. $this->error('请求方式错误');
  313. }
  314. $req = $this->request->param();
  315. $key_word = '';
  316. if (isset($req['key_word']) && !empty($req['key_word'])){
  317. $key_word = $req['key_word'];
  318. }
  319. $rs = db('物料_仓库信息')
  320. ->field('rtrim(编号) as 编号, rtrim(名称) as 名称')
  321. ->where('编号|名称','like','%'.$key_word.'%')
  322. ->where('名称','in',['面材仓库','主要产成品'])
  323. ->select();
  324. $this->success('成功',$rs);
  325. }
  326. /**
  327. * 查询印件工序及产品名称
  328. * @ApiMethod (GET)
  329. * @param string $gdbh 工单编号
  330. */
  331. public function getGd()
  332. {
  333. //get请求
  334. if(!$this->request->isGet()){
  335. $this->error('请求方式错误');
  336. }
  337. $req = $this->request->param();
  338. if (isset($req['gdbh']) && !empty($req['gdbh'])){
  339. $gdbh = $req['gdbh'];
  340. }else{
  341. $this->error('参数错误');
  342. }
  343. $rows = db('工单_基本资料')->alias('g')
  344. ->field('g.Gd_gdbh, j.yj_yjno, rtrim(g.销售订单号) as 销售订单号, rtrim(j.yj_Yjdh) as yj_Yjdh, rtrim(j.yj_yjmc) as yj_yjmc, rtrim(g.成品代号) as 成品代号, rtrim(g.成品名称) as 成品名称, rtrim(g.客户料号) as 客户料号')
  345. ->where(['g.Gd_gdbh'=>$gdbh])
  346. ->join(['工单_印件资料'=>'j'],'g.Gd_cpdh=j.yj_yjdh and g.Gd_gdbh=j.Yj_Gdbh')
  347. ->group('j.yj_yjno')
  348. ->order('j.yj_yjno asc')
  349. ->select();
  350. // $rows = db()->table('工单_印件资料')->alias('j')
  351. // ->field('g.Gd_gdbh, j.yj_Yjno as yj_yjno, rtrim(g.销售订单号) as 销售订单号, rtrim(j.yj_Yjdh) as yj_Yjdh,
  352. // rtrim(j.yj_yjmc) as yj_yjmc, rtrim(g.成品代号) as 成品代号, rtrim(g.成品名称) as 成品名称, rtrim(g.客户料号) as 客户料号')
  353. // ->where(['g.Gd_gdbh'=>$gdbh])
  354. // ->join(['工单_基本资料'=>'g'],'g.Gd_gdbh=j.Yj_Gdbh')
  355. // ->select();
  356. foreach ($rows as $key=>$value){
  357. $rows[$key]['gdyj'] = $value['Gd_gdbh'].' -'.sprintf("%02d", $value['yj_yjno']).'-'.$value['yj_yjmc'];
  358. }
  359. $this->success('成功',$rows);
  360. }
  361. /**
  362. * 查询工单数量
  363. * @ApiMethod (GET)
  364. * @param string $gdbh 工单编号
  365. * @param string $cpdh 产品代号
  366. * @param string $rcsl 入仓数量
  367. */
  368. public function getGdsl()
  369. {
  370. //get请求
  371. if(!$this->request->isGet()){
  372. $this->error('请求方式错误');
  373. }
  374. $req = $this->request->param();
  375. if (isset($req['gdbh']) && !empty($req['gdbh'])){
  376. $gdbh = $req['gdbh'];
  377. }else{
  378. $this->error('参数错误');
  379. }
  380. if (isset($req['cpdh']) && !empty($req['cpdh'])){
  381. $cpdh = $req['cpdh'];
  382. }else{
  383. $this->error('参数错误');
  384. }
  385. // if (isset($req['rcsl'])){
  386. // $rcsl = $req['rcsl'];
  387. // }else{
  388. // $this->error('参数错误');
  389. // }
  390. $rows = db('工单_基本资料')->alias('g')
  391. ->field('订单数量*10000 as 订单数量, gd_statu')
  392. ->where(['Gd_gdbh'=>$gdbh, 'Gd_cpdh'=>$cpdh])
  393. ->find();
  394. if (!$rows) $this->error('未查询到记录');
  395. $rows['jjcp_sls'] = db('糊盒成品入仓')
  396. ->where(['jjcp_gdbh'=>$gdbh, 'jjcp_cpdh'=>$cpdh])
  397. ->sum('jjcp_sl');
  398. // if ($rows['订单数量']<($rows['jjcp_sls']+$rcsl) || mb_substr($rows['gd_statu'],-3,3)=='已完工'){
  399. // $this->error('已完工或入仓数量超过订单数量',$rows);
  400. // }
  401. $this->success('成功',$rows);
  402. }
  403. /**
  404. * 新增
  405. * @ApiMethod (POST)
  406. * @param string
  407. */
  408. public function add()
  409. {
  410. if(!$this->request->isPost()){
  411. $this->error('请求方式错误');
  412. }
  413. //连接mongodb
  414. $mongodb = Db::connect(config('database.mongodb'));
  415. $req = $this->request->param();
  416. $arr = [
  417. 'Sys_id',
  418. '入仓类型', '仓库编号', '仓库名称',
  419. 'jjcp_num',
  420. 'jjcp_gdbh', 'jjcp_yjno', '订单编号',
  421. 'jjcp_cpdh', 'jjcp_cpmc',
  422. '成品编码', '成品名称',
  423. '客户料号',
  424. 'jjcp_smb', 'jjcp_sj',
  425. 'jjcp_sl', 'jjcp_dw',
  426. '机型备注',
  427. 'jjcp_desc'
  428. ];
  429. $name = \db('工单_印件资料')
  430. ->where('Yj_Gdbh',$req['jjcp_gdbh'])
  431. ->where('yj_Yjno',$req['jjcp_yjno'])
  432. ->value('yj_yjmc');
  433. if ($name !== $req['jjcp_cpmc']){
  434. $this->error('产品名称错误');
  435. }
  436. $data = [];
  437. foreach ($arr as $key => $value){
  438. if (!isset($req[$value])){
  439. $this->error('参数错误',$value,$key+1);
  440. }
  441. $data[$value] = $req[$value];
  442. }
  443. $data['Sys_rq'] = date('Y-m-d H:i:s');
  444. //查询UniqId
  445. $UniqId = db('糊盒成品入仓')->max('UniqId');
  446. $data['UniqId'] = $UniqId < 10000000 ? 10000000 : $UniqId + 1;
  447. //判断当前工单是否存在已提交模版
  448. $existingRecord = db('糊盒成品入仓')
  449. ->where('jjcp_gdbh', $data['jjcp_gdbh'])
  450. ->where('jjcp_yjno', $data['jjcp_yjno'])
  451. ->where('jjcp_smb', '<>', '') // 判断 jjcp_smb 不为空
  452. ->find();
  453. if ($existingRecord) {
  454. $this->error($existingRecord['jjcp_gdbh'].'工单 -- 印件'.$existingRecord['jjcp_yjno'].'已经进入末版,无法继续操作');
  455. }
  456. //开启事务
  457. db()->startTrans();
  458. try{
  459. $sql = db('糊盒成品入仓')->fetchSql(true)->insert($data);
  460. $bool = db()->query($sql);
  461. //新增进MongoDB
  462. $res = $mongodb->name('finished_products')->insert($data);
  463. // 提交事务
  464. db()->commit();
  465. } catch (\Exception $e) {
  466. // 回滚事务
  467. db()->rollback();
  468. $this->error($e->getMessage());
  469. }
  470. if($bool===false) $this->error('失败');
  471. $this->success('成功');
  472. }
  473. /**
  474. * 修改
  475. * @ApiMethod (POST)
  476. */
  477. public function edit()
  478. {
  479. if(!$this->request->isPost()){
  480. $this->error('请求方式错误');
  481. }
  482. //连接mongodb
  483. $mongodb = Db::connect(config('database.mongodb'));
  484. $req = $this->request->param();
  485. $arr = [
  486. '入仓类型', '仓库编号', '仓库名称',
  487. 'jjcp_num',
  488. 'jjcp_gdbh', 'jjcp_yjno', '订单编号',
  489. 'jjcp_cpdh', 'jjcp_cpmc',
  490. '成品编码', '成品名称',
  491. '客户料号',
  492. 'jjcp_smb', 'jjcp_sj',
  493. 'jjcp_sl', 'jjcp_dw',
  494. '机型备注',
  495. 'jjcp_desc'
  496. ];
  497. $data = [];
  498. foreach ($arr as $key => $value){
  499. if (!isset($req[$value])){
  500. continue;
  501. }
  502. $data[$value] = $req[$value];
  503. }
  504. if (!(isset($req['UniqId']) && trim($req['UniqId'])!='')){
  505. $this->error('参数错误','UniqId',100);
  506. }
  507. if (count($data)==0){
  508. $this->error('参数错误','',111);
  509. }
  510. $data['Mod_rq'] = date('Y-m-d H:i:s');
  511. //判断当前工单是否存在已提交模版
  512. if ($data['jjcp_smb'] === '末 板'){
  513. $existingRecord = db('糊盒成品入仓')
  514. ->where('jjcp_gdbh', $data['jjcp_gdbh'])
  515. ->where('jjcp_yjno', $data['jjcp_yjno'])
  516. ->where('jjcp_smb', '<>', '') // 判断 jjcp_smb 不为空
  517. ->find();
  518. if ($existingRecord && $existingRecord['UniqId'] !== (int)$req['UniqId']) {
  519. $this->error($existingRecord['jjcp_gdbh'].'工单 -- 印件'.$existingRecord['jjcp_yjno'].'已经进入末版,无法继续操作');
  520. }
  521. };
  522. //开启事务
  523. db()->startTrans();
  524. try{
  525. $sql = db('糊盒成品入仓')->where('UniqId',$req['UniqId'])->fetchSql(true)->update($data);
  526. $bool = db()->query($sql);
  527. //同步更新monodb数据
  528. $res = $mongodb->name('finished_products')
  529. ->where('UniqId', (int)$req['UniqId']) // 使用实际的UniqId值
  530. ->update($data);
  531. // 提交事务
  532. db()->commit();
  533. } catch (\Exception $e) {
  534. // 回滚事务
  535. db()->rollback();
  536. $this->error($e->getMessage());
  537. }
  538. if($bool===false) $this->error('失败');
  539. $this->success('成功');
  540. }
  541. /**
  542. * 修改
  543. * @ApiMethod (POST)
  544. * @param string 'UniqId'
  545. */
  546. public function del()
  547. {
  548. if(!$this->request->isPost()){
  549. $this->error('请求方式错误');
  550. }
  551. //连接mongodb
  552. $mongodb = Db::connect(config('database.mongodb'));
  553. $req = $this->request->param();
  554. if (!(isset($req['UniqId']) && trim($req['UniqId'])!='')){
  555. $this->error('参数错误','UniqId',100);
  556. }
  557. //开启事务
  558. db()->startTrans();
  559. try{
  560. $bool = db('糊盒成品入仓')->where('UniqId',$req['UniqId'])->delete();
  561. //同时删除mongdb数据
  562. //同步更新monodb数据
  563. $res = $mongodb->name('finished_products')
  564. ->where('UniqId', (int)$req['UniqId']) // 使用实际的UniqId值
  565. ->delete();
  566. // 提交事务
  567. db()->commit();
  568. } catch (\Exception $e) {
  569. // 回滚事务
  570. db()->rollback();
  571. $this->error($e->getMessage());
  572. }
  573. if($bool===false) $this->error('失败');
  574. $this->success('成功');
  575. }
  576. /**
  577. * excel导出
  578. * @ApiMethod (POST)
  579. * @param string date
  580. * @param string sys_id
  581. * @param array fields
  582. */
  583. public function export(){
  584. if(!$this->request->isGet()){
  585. $this->error('请求方式错误');
  586. }
  587. $req = $this->request->param();
  588. if (!isset($req['date'])) $this->error('参数缺失');
  589. if (!(isset($req['fields']) && count($req['fields'])!=0)){
  590. $this->error('参数错误','fields',100);
  591. }
  592. if(strpos($req['date'],'-')){
  593. $where = ['c.Sys_rq'=>['like',$req['date'].'%']];
  594. }else if(empty($req['date'])){
  595. $where = [];
  596. }else{
  597. $where = ['c.jjcp_gdbh'=>$req['date']];
  598. }
  599. if (isset($req['sys_id']) && !empty($req['sys_id'])){
  600. $where['c.Sys_id'] = ['LIKE',$req['sys_id'].'%'];
  601. }
  602. $arr = [
  603. '入仓类型' =>['入仓类型'],
  604. '仓库编号' =>['仓库编号'],
  605. '仓库名称' =>['仓库名称'],
  606. 'jjcp_num' =>['入仓单号'],
  607. 'jjcp_gdbh' =>['工单编号'],
  608. 'jjcp_yjno' =>['印件号'],
  609. 'jjcp_sl' =>['入仓数量'],
  610. 'jjcp_sls' =>['累计入仓数量'],
  611. '订单数量' =>['订单数量'],
  612. '完成率' =>['完成率'],
  613. 'jjcp_dw' =>['单位'],
  614. 'jjcp_sj' =>['入仓时间'],
  615. 'jjcp_smb' =>['首末板'],
  616. 'jjcp_cpdh' =>['印件代号'],
  617. 'jjcp_cpmc' =>['印件名称'],
  618. '成品编码' =>['产品编号'],
  619. '成品名称' =>['产品名称'],
  620. '客户料号' =>['客户料号'],
  621. 'jjcp_desc' =>['备注'],
  622. '客户编号' =>['客户编号'],
  623. 'Gd_客户名称' =>['客户名称'],
  624. '最近入仓日期' =>['最近入仓日期'],
  625. '机型备注' =>['机型备注'],
  626. ];
  627. $data[0] = [];
  628. foreach ($req['fields'] as $k=>$v){
  629. if(array_key_exists($v,$arr)){
  630. array_push($data[0],$arr[$v][0]);
  631. }
  632. }
  633. $num = db('糊盒成品入仓')->alias('c')
  634. ->where($where)
  635. ->where('g.Gd_cpdh=c.jjcp_cpdh')
  636. ->join('工单_基本资料 g','g.Gd_gdbh=c.jjcp_gdbh')
  637. ->count();
  638. $rows = [];
  639. for($i=1;$i<=ceil($num/10000);$i++){
  640. $p = $i == ceil($num/10000) ? $num%10000 : 10000;
  641. $r = db('糊盒成品入仓')->alias('c')
  642. ->field('rtrim(c.入仓类型) as 入仓类型, rtrim(c.仓库编号) as 仓库编号, rtrim(c.仓库名称) as 仓库名称,
  643. rtrim(c.jjcp_num) as jjcp_num, c.jjcp_gdbh,
  644. c.jjcp_yjno, c.jjcp_sl, g.订单数量, rtrim(c.jjcp_dw) as jjcp_dw, LEFT(c.jjcp_sj, 10) as jjcp_sj,
  645. rtrim(c.jjcp_smb) as jjcp_smb, rtrim(c.jjcp_cpdh) as jjcp_cpdh, rtrim(c.jjcp_cpmc) as jjcp_cpmc,
  646. rtrim(c.成品编码) as 成品编码, rtrim(c.成品名称) as 成品名称,
  647. rtrim(c.客户料号) as 客户料号, rtrim(c.jjcp_desc) as jjcp_desc, LEFT(c.成品编码,'.config('product_code_digit').') as 客户编号, rtrim(g.Gd_客户名称) as Gd_客户名称,
  648. rtrim(c.机型备注) as 机型备注')
  649. ->where($where)
  650. ->where('g.Gd_cpdh=c.jjcp_cpdh')
  651. ->join('工单_基本资料 g','g.Gd_gdbh=c.jjcp_gdbh')
  652. ->order('c.UniqId desc')
  653. ->limit($i,$p)
  654. ->select();
  655. $rows = array_merge($rows,$r);
  656. }
  657. foreach ($rows as $key=>$value) {
  658. $row = db('糊盒成品入仓')
  659. ->field('LEFT(Sys_rq, 10) as Sys_rq,jjcp_sl')
  660. ->where(['jjcp_gdbh'=>$value['jjcp_gdbh'], 'jjcp_cpdh'=>$value['jjcp_cpdh']])
  661. ->order('Sys_rq desc')
  662. ->select();
  663. $subArray = [];
  664. foreach ($arr as $k=>$v){
  665. if($k=='jjcp_sls'){
  666. $subArray[$k] = 0;
  667. foreach ($row as $n) {
  668. $subArray[$k] += $n['jjcp_sl'];
  669. }
  670. }else if($k=='完成率'){
  671. if ($value['订单数量']!=0){
  672. $subArray[$k] = 0;
  673. foreach ($row as $n) {
  674. $subArray[$k] += $n['jjcp_sl'];
  675. }
  676. $subArray[$k] = number_format($subArray[$k]/$value['订单数量']/100,2);
  677. }else{
  678. $subArray[$k] = '';
  679. }
  680. }else if($k=='最近入仓日期'){
  681. $subArray[$k] = $row[0]['Sys_rq'];
  682. }else{
  683. $subArray[$k] = $rows[$key][$k];
  684. }
  685. }
  686. array_push($data,$subArray);
  687. }
  688. $this->success('成功',['file_name'=>$req['file_name'],'data'=>$data]);
  689. }
  690. /**
  691. * 月度A
  692. * @ApiMethod (POST)
  693. * @param string start_time
  694. * @param string end_time
  695. * @param string file_name
  696. * @param array fields
  697. */
  698. public function monthExportA(){
  699. if(!$this->request->isGet()){
  700. $this->error('请求方式错误');
  701. }
  702. $req = $this->request->param();
  703. $arr = [
  704. 'start_time', 'end_time', 'file_name'
  705. ];
  706. foreach ($arr as $key => $value){
  707. if (!isset($req[$value])){
  708. $this->error('参数错误',$value,$key+1);
  709. }
  710. }
  711. if (!(isset($req['fields']) && count($req['fields'])!=0)){
  712. $this->error('参数错误','fields',100);
  713. }
  714. $arr = [
  715. '入仓类型' =>['入仓类型'],
  716. '仓库编号' =>['仓库编号'],
  717. '仓库名称' =>['仓库名称'],
  718. 'jjcp_gdbh' =>['工单编号'],
  719. 'jjcp_cpdh' =>['入仓存货编号'],
  720. 'jjcp_cpmc' =>['入仓存货名称'],
  721. 'jjcp_sl' =>['入仓数量'],
  722. 'jjcp_dw' =>['单位'],
  723. 'jjcp_sj' =>['入仓时间'],
  724. 'jjcp_smb' =>['首末板'],
  725. 'jjcp_num' =>['单据编号'],
  726. '订单编号' =>['订单编号'],
  727. ];
  728. $data[0] = [];
  729. foreach ($req['fields'] as $k=>$v){
  730. if(array_key_exists($v,$arr)){
  731. array_push($data[0],$arr[$v][0]);
  732. }
  733. }
  734. //客户编号
  735. $rows = db('糊盒成品入仓')->alias('c')
  736. ->field('rtrim(c.入仓类型) as 入仓类型, rtrim(c.仓库编号) as 仓库编号, rtrim(c.仓库名称) as 仓库名称,
  737. c.jjcp_gdbh, rtrim(c.jjcp_cpdh) as jjcp_cpdh, rtrim(c.jjcp_cpmc) as jjcp_cpmc,
  738. c.jjcp_sl, rtrim(c.jjcp_dw) as jjcp_dw, c.jjcp_sj,
  739. rtrim(c.jjcp_smb) as jjcp_smb,
  740. rtrim(c.jjcp_num) as jjcp_num, rtrim(c.订单编号) as 订单编号
  741. ')
  742. ->where('c.jjcp_sj','between time',[$req['start_time'], $req['end_time']])
  743. ->order('c.jjcp_sj asc')
  744. ->join('工单_基本资料 g','g.Gd_gdbh=c.jjcp_gdbh')
  745. ->where('g.Gd_cpdh=c.jjcp_cpdh')
  746. ->select();
  747. foreach ($rows as $key=>$value) {
  748. $subArray = [];
  749. foreach ($arr as $k=>$v){
  750. $subArray[$k] = $rows[$key][$k];
  751. }
  752. array_push($data,$subArray);
  753. }
  754. $this->success('成功',['file_name'=>$req['file_name'],'data'=>$data]);
  755. }
  756. /**
  757. * 月度B
  758. * @ApiMethod (POST)
  759. * @param string start_time
  760. * @param string end_time
  761. * @param string file_name
  762. * @param array fields
  763. */
  764. public function monthExportB(){
  765. if(!$this->request->isGet()){
  766. $this->error('请求方式错误');
  767. }
  768. $req = $this->request->param();
  769. $arr = [
  770. 'start_time', 'end_time', 'file_name'
  771. ];
  772. foreach ($arr as $key => $value){
  773. if (!isset($req[$value])){
  774. $this->error('参数错误',$value,$key+1);
  775. }
  776. }
  777. if (!(isset($req['fields']) && count($req['fields'])!=0)){
  778. $this->error('参数错误','fields',100);
  779. }
  780. $arr = [
  781. '入仓类型' =>['入仓类型'],
  782. '客户编号' =>['客户编号'],
  783. '客户名称' =>['客户名称'],
  784. '产品类别' =>['产品类别'],
  785. 'jjcp_gdbh' =>['工单编号'],
  786. '成品编码' =>['成品编码'],
  787. '成品名称' =>['成品名称'],
  788. 'jjcp_sls' =>['入仓数量'],
  789. '大箱产量' =>['大箱产量'],
  790. '产品单价' =>['万张单价'],
  791. '产值万元' =>['产值万元'],
  792. ];
  793. $data[0] = [];
  794. foreach ($req['fields'] as $k=>$v){
  795. if(array_key_exists($v,$arr)){
  796. array_push($data[0],$arr[$v][0]);
  797. }
  798. }
  799. $rows1 = db('糊盒成品入仓')->alias('c')
  800. ->field('rtrim(c.入仓类型) as 入仓类型, LEFT(c.成品编码,'.config('product_code_digit').') as 客户编号, rtrim(b.客户名称) as 客户名称,
  801. rtrim(b.产品类别) as 产品类别, c.jjcp_gdbh,
  802. rtrim(c.成品编码) as 成品编码, rtrim(c.成品名称) as 成品名称
  803. ')
  804. ->where('c.jjcp_sj','between time',[$req['start_time'], $req['end_time']])
  805. ->order('客户编号 asc,b.产品类别 desc,c.成品编码 asc,c.jjcp_gdbh asc')
  806. ->join('产品_基本资料 b','b.产品编号=c.jjcp_cpdh')
  807. ->group('c.jjcp_gdbh')
  808. ->select();
  809. $rows2 = db('糊盒成品入仓')
  810. ->field('rtrim(入仓类型) as 入仓类型, rtrim(成品编码) as 客户编号,
  811. rtrim(成品编码) as 客户名称, rtrim(成品编码) as 产品类别,
  812. jjcp_gdbh,rtrim(成品编码) as 成品编码, rtrim(成品名称) as 成品名称
  813. ')
  814. ->where('jjcp_sj','between time',[$req['start_time'], $req['end_time']])
  815. ->where('成品编码','')
  816. ->order('jjcp_gdbh asc')
  817. ->group('jjcp_gdbh')
  818. ->select();
  819. $rows = array_merge($rows2,$rows1);
  820. $num = db('工单_基本资料')->count();
  821. $arr1 = db('工单_基本资料')->limit($num)
  822. ->column('CONCAT(Gd_gdbh, "-", rtrim(Gd_cpdh)) AS gdcp, 产品单价 as 万张单价');
  823. $brr = array_column($rows,'jjcp_gdbh');
  824. $brr = db('糊盒成品入仓')
  825. ->where('jjcp_gdbh', 'in', $brr)
  826. ->group('jjcp_gdbh')
  827. ->column('jjcp_gdbh, sum(jjcp_sl)');
  828. foreach ($rows as $key=>$value) {
  829. $subArray = [];
  830. foreach ($arr as $k=>$v){
  831. if($k=='jjcp_sls'){
  832. $subArray[$k] = $brr[$value['jjcp_gdbh']];
  833. }else if ($k=='大箱产量'){
  834. if($value['产品类别']=='条盒'){
  835. $subArray[$k] = $brr[$value['jjcp_gdbh']]/250;
  836. }else if($value['产品类别']=='小盒'){
  837. $subArray[$k] = $brr[$value['jjcp_gdbh']]/2500;
  838. }else{
  839. $subArray[$k] = 0;
  840. }
  841. }else if ($k=='产品单价'){
  842. if($value['产品类别']!=''){
  843. if (array_key_exists($value['jjcp_gdbh'].'-'.$value['成品编码'],$arr1)){
  844. $subArray[$k] = floatval(number_format($arr1[$value['jjcp_gdbh'].'-'.$value['成品编码']],4));
  845. }
  846. }else{
  847. $subArray[$k] = 0;
  848. }
  849. }else if ($k=='产值万元'){
  850. if($value['产品类别']!=''){
  851. if (array_key_exists($value['jjcp_gdbh'].'-'.$value['成品编码'],$arr1)){
  852. $subArray[$k] = floatval(number_format($arr1[$value['jjcp_gdbh'].'-'.$value['成品编码']]*$brr[$value['jjcp_gdbh']]/100000000,2));
  853. }
  854. }else{
  855. $subArray[$k] = 0;
  856. }
  857. }else{
  858. $subArray[$k] = $rows[$key][$k];
  859. }
  860. }
  861. array_push($data,$subArray);
  862. }
  863. $this->success('成功',['file_name'=>$req['file_name'],'data'=>$data]);
  864. }
  865. /**
  866. * 各日统计列表
  867. * @ApiMethod (GET)
  868. * @param string $date 时间
  869. * @param string $sys_id 用户
  870. */
  871. public function getDayList()
  872. {
  873. //get请求
  874. if(!$this->request->isGet()){
  875. $this->error('请求方式错误');
  876. }
  877. $req = $this->request->param();
  878. $page = 1;
  879. $limit = 15;
  880. if (isset($req['page']) && !empty($req['page'])) $page = $req['page'];
  881. if (isset($req['limit']) && !empty($req['limit'])) $limit = $req['limit'];
  882. $where = [
  883. 'c.jjcp_smb'=>['<>',''],
  884. ];
  885. if (isset($req['key_word']) && !empty($req['key_word'])){
  886. $where['c.jjcp_sj | c.jjcp_gdbh | c.jjcp_cpmc | c.jjcp_cpdh | g.实际投料'] = ['like','%'.$req['key_word'].'%'];
  887. }
  888. //客户编号
  889. $rows = db('糊盒成品入仓')->alias('c')
  890. ->field('LEFT(c.jjcp_sj, 10) as jjcp_sj, c.jjcp_gdbh, rtrim(c.jjcp_cpmc) as jjcp_cpmc,
  891. rtrim(c.jjcp_cpdh) as jjcp_cpdh, g.实际投料')
  892. ->where($where)
  893. ->where('g.Gd_cpdh=c.jjcp_cpdh')
  894. ->join('工单_基本资料 g','g.Gd_gdbh=c.jjcp_gdbh')
  895. ->order('c.jjcp_sj desc')
  896. ->group('c.jjcp_gdbh, c.jjcp_cpdh')
  897. ->page($page,$limit)
  898. ->select();
  899. $total = db('糊盒成品入仓')->alias('c')
  900. ->where($where)
  901. ->where('g.Gd_cpdh=c.jjcp_cpdh')
  902. ->join('工单_基本资料 g','g.Gd_gdbh=c.jjcp_gdbh')
  903. ->group('c.jjcp_gdbh, c.jjcp_cpdh')
  904. ->count();
  905. $brr = db('糊盒成品入仓')
  906. ->group('jjcp_gdbh,jjcp_cpdh')
  907. ->column('CONCAT(jjcp_gdbh, "-", rtrim(jjcp_cpdh)), sum(jjcp_sl)');
  908. foreach ($rows as $key=>$value) {
  909. $rows[$key]['实际投料'] = (string)floatval($value['实际投料']*10000);
  910. if(array_key_exists($value['jjcp_gdbh'].'-'.$value['jjcp_cpdh'],$brr)){
  911. $rows[$key]['入仓数量'] = $brr[$value['jjcp_gdbh'].'-'.$value['jjcp_cpdh']];
  912. if($rows[$key]['实际投料']!=0){
  913. $rows[$key]['投入产出率'] = number_format($rows[$key]['入仓数量']/$rows[$key]['实际投料']*100,2);
  914. }else{
  915. $rows[$key]['投入产出率'] = '';
  916. }
  917. }else{
  918. $rows[$key]['入仓数量'] = '';
  919. $rows[$key]['投入产出率'] = '';
  920. }
  921. }
  922. $data = [
  923. 'total' => $total,
  924. 'rows' => $rows,
  925. ];
  926. $this->success('成功',$data);
  927. }
  928. /**
  929. * 各日统计列表excel导出
  930. * @ApiMethod (POST)
  931. * @param string file_name
  932. * @param array fields
  933. */
  934. public function dayExport()
  935. {
  936. //get请求
  937. if(!$this->request->isPost()){
  938. $this->error('请求方式错误');
  939. }
  940. $req = $this->request->param();
  941. if (!isset($req['file_name'])){
  942. $this->error('参数错误','file_name');
  943. }
  944. if (!(isset($req['fields']) && count($req['fields'])!=0)){
  945. $this->error('参数错误','fields',100);
  946. }
  947. if (isset($req['key_word']) && !empty($req['key_word'])){
  948. $where['c.jjcp_sj | c.jjcp_gdbh | c.jjcp_cpmc | c.jjcp_cpdh | g.实际投料'] = ['like','%'.$req['key_word'].'%'];
  949. }
  950. $arr = [
  951. 'jjcp_gdbh' =>['jjcp_gdbh'],
  952. 'jjcp_yjno' =>['jjcp_yjno'],
  953. 'jjcp_cpmc' =>['印件名称'],
  954. '成品编码' =>['成品编码'],
  955. '成品名称' =>['成品名称'],
  956. '实际投料' =>['实际投料'],
  957. 'jjcp_sls' =>['入仓数量'],
  958. 'jjcp_sj' =>['完工日期'],
  959. ];
  960. $data[0] = [];
  961. foreach ($req['fields'] as $k=>$v){
  962. if(array_key_exists($v,$arr)){
  963. array_push($data[0],$arr[$v][0]);
  964. }
  965. }
  966. $where = [
  967. 'c.jjcp_smb'=>['<>','']
  968. ];
  969. //客户编号
  970. $rows = db('糊盒成品入仓')->alias('c')
  971. ->field('c.jjcp_gdbh, c.jjcp_yjno, rtrim(c.jjcp_cpmc) as jjcp_cpmc, rtrim(c.jjcp_cpdh) as jjcp_cpdh,
  972. rtrim(c.成品编码) as 成品编码, rtrim(c.成品名称) as 成品名称, sum(jjcp_sl) as jjcp_sls,
  973. g.实际投料, LEFT(c.jjcp_sj, 10) as jjcp_sj
  974. ')
  975. ->where($where)
  976. ->where('g.Gd_cpdh=c.jjcp_cpdh')
  977. ->join('工单_基本资料 g','g.Gd_gdbh=c.jjcp_gdbh')
  978. ->order('c.jjcp_sj desc')
  979. ->group('c.jjcp_gdbh, c.jjcp_cpdh')
  980. ->select();
  981. foreach ($rows as $key=>$value) {
  982. $subArray = [];
  983. foreach ($arr as $k=>$v){
  984. if($k=='实际投料'){
  985. $subArray[$k] = (string)floatval($value['实际投料']*10000);
  986. }else{
  987. $subArray[$k] = $rows[$key][$k];
  988. }
  989. }
  990. array_push($data,$subArray);
  991. }
  992. $this->success('成功',['file_name'=>$req['file_name'],'data'=>$data]);
  993. }
  994. /**
  995. * 入仓末板数据统计列表
  996. * @ApiMethod (GET)
  997. * @param string $date 时间
  998. * @param string $sys_id 用户
  999. */
  1000. public function mbList()
  1001. {
  1002. //get请求
  1003. if(!$this->request->isGet()){
  1004. $this->error('请求方式错误');
  1005. }
  1006. $req = $this->request->param();
  1007. // $page = 1;
  1008. // $limit = 15;
  1009. // if (isset($req['page']) && !empty($req['page'])) $page = $req['page'];
  1010. // if (isset($req['limit']) && !empty($req['limit'])) $limit = $req['limit'];
  1011. $date = date('Y-m-d',strtotime('-3 month'));
  1012. $arr1 = db('db_包装产量预报')
  1013. ->field('sczl_gdbh1, sczl_gdbh2, sczl_gdbh3, sczl_gdbh4, sczl_gdbh5, sczl_gdbh6,
  1014. cast(substr(sczl_yjGx1,1,2) as signed) as sczl_yjGx1, cast(substr(sczl_yjGx2,1,2) as signed) as sczl_yjGx2,
  1015. cast(substr(sczl_yjGx3,1,2) as signed) as sczl_yjGx3, cast(substr(sczl_yjGx4,1,2) as signed) as sczl_yjGx4,
  1016. cast(substr(sczl_yjGx5,1,2) as signed) as sczl_yjGx5, cast(substr(sczl_yjGx6,1,2) as signed) as sczl_yjGx6,
  1017. (sczl_cl1*sczl_PgCl1+sczl_clAdd1) as sczl_cls1,
  1018. (sczl_cl2*sczl_PgCl2+sczl_clAdd2) as sczl_cls2,
  1019. (sczl_cl3*sczl_PgCl3+sczl_clAdd3) as sczl_cls3,
  1020. (sczl_cl4*sczl_PgCl4+sczl_clAdd4) as sczl_cls4,
  1021. (sczl_cl5*sczl_PgCl5+sczl_clAdd5) as sczl_cls5,
  1022. (sczl_cl6*sczl_PgCl6+sczl_clAdd6) as sczl_cls6
  1023. ')
  1024. ->where('sczl_rq','>=',$date)
  1025. ->select();
  1026. $data1 = [];
  1027. foreach ($arr1 as $k=>$v){
  1028. for ($i=1;$i<=6;$i++){
  1029. if (!empty($v['sczl_gdbh'.$i])){
  1030. $v['sczl_gdbh'.$i] = strtoupper($v['sczl_gdbh'.$i]);
  1031. if(array_key_exists($v['sczl_gdbh'.$i].'-'.$v['sczl_yjGx'.$i],$data1)){
  1032. $data1[$v['sczl_gdbh'.$i].'-'.$v['sczl_yjGx'.$i]] += $v['sczl_cls'.$i];
  1033. }else{
  1034. $data1[$v['sczl_gdbh'.$i].'-'.$v['sczl_yjGx'.$i]] = $v['sczl_cls'.$i];
  1035. }
  1036. }
  1037. }
  1038. }
  1039. krsort($data1);
  1040. //糊盒成品入仓中jjcp_smb不为空的工单
  1041. // $rows1 = db('糊盒成品入仓')
  1042. // ->where('jjcp_smb','<>','')
  1043. // ->order('jjcp_gdbh desc')
  1044. // ->column("CONCAT(jjcp_gdbh, '-', jjcp_yjno) AS gdyj, UniqId");
  1045. $rows2 = db('糊盒成品入仓')
  1046. ->where('jjcp_sj','>=',$date)
  1047. ->group('jjcp_gdbh, jjcp_cpdh')
  1048. ->column("CONCAT( jjcp_gdbh, '-', jjcp_yjno) AS gdyj, max(jjcp_smb) as jjcp_smb,
  1049. sum(jjcp_sl) as jjcp_sls, left(max(jjcp_sj),10) as jjcp_sj,UniqId");
  1050. // $rows3 = db('工单_印件资料')->cache(true,86400)
  1051. // ->group('Yj_Gdbh, yj_Yjno')
  1052. // ->column("CONCAT( Yj_Gdbh, '-', yj_Yjno) AS gdyj,
  1053. // Yj_Gdbh, yj_Yjno, yj_yjmc, yj_成品数量, yj_实际投料");
  1054. $data = [];
  1055. foreach($data1 as $key=>$value){
  1056. // if(!array_key_exists($key,$rows1)){
  1057. $subArray = [];
  1058. $gdbh = strtoupper(explode('-',$key)[0]);
  1059. $yjno = explode('-',$key)[1];
  1060. $res = db('工单_印件资料')
  1061. ->where('Yj_Gdbh',$gdbh)
  1062. ->where('yj_Yjno',$yjno)
  1063. ->field('Yj_Gdbh, yj_Yjno, yj_yjmc, yj_成品数量, (yj_平张投料 * yj_ks * yj_ls) as 投料')
  1064. ->find();
  1065. if(!empty($res)){
  1066. $subArray['Yj_Gdbh'] = $res['Yj_Gdbh'];
  1067. $subArray['yj_Yjno'] = $res['yj_Yjno'];
  1068. $subArray['yj_yjmc'] = trim($res['yj_yjmc']);
  1069. $subArray['yj_成品数量'] = (string)floatval($res['yj_成品数量']*10000);
  1070. $subArray['yj_实际投料'] = (string)floatval($res['投料']);
  1071. }else{
  1072. $subArray['Yj_Gdbh'] = '';
  1073. $subArray['yj_Yjno'] = '';
  1074. $subArray['yj_yjmc'] = '';
  1075. $subArray['yj_成品数量'] = '';
  1076. $subArray['yj_实际投料'] = '';
  1077. }
  1078. if(array_key_exists($key,$rows2)){
  1079. $subArray['jjcp_smb'] = $rows2[$key]['jjcp_smb'];
  1080. $subArray['jjcp_sls'] = $rows2[$key]['jjcp_sls'];
  1081. $subArray['jjcp_sj'] = $rows2[$key]['jjcp_sj'];
  1082. }else{
  1083. $subArray['jjcp_smb'] = '';
  1084. $subArray['jjcp_sls'] = '';
  1085. $subArray['jjcp_sj'] = '';
  1086. }
  1087. $subArray['sczl_cls'] = (string)floatval($value);
  1088. array_push($data,$subArray);
  1089. }
  1090. // }
  1091. // $rows = db('db_包装产量预报')
  1092. // ->field('sczl_rq,sczl_gdbh1,sczl_gdbh2,sczl_gdbh3,sczl_gdbh4,sczl_gdbh5,sczl_gdbh6,Sys_rq,mod_rq,UniqId')
  1093. // ->where('Sys_rq','>=','2023-10-25')
  1094. // ->select();
  1095. // $uniqueValues = [];
  1096. // foreach ($rows as $row) {
  1097. // $gdbhArray = array($row['sczl_gdbh1'], $row['sczl_gdbh2'], $row['sczl_gdbh3'], $row['sczl_gdbh4'], $row['sczl_gdbh5'], $row['sczl_gdbh6']);
  1098. // $uniqueValues = array_merge($uniqueValues, array_unique($gdbhArray));
  1099. // }
  1100. // $uniqueValues = array_values(array_unique($uniqueValues));
  1101. // halt($uniqueValues);
  1102. // $rows = db('糊盒成品入仓')->alias('c')
  1103. // ->field('c.jjcp_gdbh, c.jjcp_yjno, rtrim(c.jjcp_cpmc) as jjcp_cpmc,
  1104. // y.yj_成品数量, y.yj_实际投料, rtrim(c.jjcp_cpdh) as jjcp_cpdh, rtrim(c.jjcp_smb) as jjcp_smb,
  1105. // sum(c.jjcp_sl) as jjcp_sls, left(max(c.Sys_rq),10) as Sys_rq')
  1106. // ->where($where)
  1107. // ->where('y.yj_Yjdh=c.jjcp_cpdh')
  1108. // ->join('工单_印件资料 y','y.Yj_Gdbh=c.jjcp_gdbh')
  1109. // ->order('c.jjcp_gdbh desc, c.jjcp_yjno asc')
  1110. // ->group('c.jjcp_gdbh, c.jjcp_cpdh')
  1111. // ->page($page,$limit)
  1112. // ->select();
  1113. // $total = db('糊盒成品入仓')->alias('c')
  1114. // ->where($where)
  1115. // ->where('y.yj_Yjdh=c.jjcp_cpdh')
  1116. // ->join('工单_印件资料 y','y.Yj_Gdbh=c.jjcp_gdbh')
  1117. // ->group('c.jjcp_gdbh, c.jjcp_cpdh')
  1118. // ->count();
  1119. // $brr = db('糊盒成品入仓')
  1120. // ->group('jjcp_gdbh,jjcp_cpdh')
  1121. // ->column('CONCAT(jjcp_gdbh, "-", rtrim(jjcp_cpdh)), sum(jjcp_sl)');
  1122. // $num = db('db_包装产量预报')->count();
  1123. // $arr1 = db('db_包装产量预报')
  1124. // ->field('sczl_gdbh1, sczl_gdbh2, sczl_gdbh3, sczl_gdbh4, sczl_gdbh5, sczl_gdbh6,
  1125. // substr(sczl_yjGx1,2,1) as sczl_yjGx1, substr(sczl_yjGx2,2,1) as sczl_yjGx2,
  1126. // substr(sczl_yjGx3,2,1) as sczl_yjGx3, substr(sczl_yjGx4,2,1) as sczl_yjGx4,
  1127. // substr(sczl_yjGx5,2,1) as sczl_yjGx5, substr(sczl_yjGx6,2,1) as sczl_yjGx6,
  1128. // (sczl_cl1*sczl_PgCl1+sczl_clAdd1) as sczl_cls1,
  1129. // (sczl_cl2*sczl_PgCl2+sczl_clAdd2) as sczl_cls2,
  1130. // (sczl_cl3*sczl_PgCl3+sczl_clAdd3) as sczl_cls3,
  1131. // (sczl_cl4*sczl_PgCl4+sczl_clAdd4) as sczl_cls4,
  1132. // (sczl_cl5*sczl_PgCl5+sczl_clAdd5) as sczl_cls5,
  1133. // (sczl_cl6*sczl_PgCl6+sczl_clAdd6) as sczl_cls6
  1134. // ')
  1135. // ->limit($num)
  1136. // ->select();
  1137. // $data1 = [];
  1138. // foreach ($arr1 as $k=>$v){
  1139. // for ($i=1;$i<=6;$i++){
  1140. // if(array_key_exists($v['sczl_gdbh'.$i].'-'.$v['sczl_yjGx'.$i],$data1)){
  1141. // $data1[$v['sczl_gdbh'.$i].'-'.$v['sczl_yjGx'.$i]] += $v['sczl_cls'.$i];
  1142. // }else{
  1143. // $data1[$v['sczl_gdbh'.$i].'-'.$v['sczl_yjGx'.$i]] = $v['sczl_cls'.$i];
  1144. // }
  1145. // }
  1146. // }
  1147. // foreach ($rows as $key=>$value) {
  1148. // $rows[$key]['yj_成品数量'] = (string)floatval($value['yj_成品数量']*10000);
  1149. // $rows[$key]['yj_实际投料'] = (string)floatval($value['yj_实际投料']*10000);
  1150. // if(array_key_exists($value['jjcp_gdbh'].'-'.$value['jjcp_yjno'],$data1)){
  1151. // $rows[$key]['包装产量'] = $data1[$value['jjcp_gdbh'].'-'.$value['jjcp_yjno']];
  1152. // }else{
  1153. // $rows[$key]['包装产量'] = '';
  1154. // }
  1155. // if(array_key_exists($value['jjcp_gdbh'].'-'.$value['jjcp_cpdh'],$brr)){
  1156. // $rows[$key]['入仓数量'] = $brr[$value['jjcp_gdbh'].'-'.$value['jjcp_cpdh']];
  1157. // }else{
  1158. // $rows[$key]['入仓数量'] = '';
  1159. // }
  1160. // if($value['jjcp_smb'] !=''){
  1161. // $rows[$key]['状态'] = '完工';
  1162. // $rows[$key]['缺数'] = (int)$rows[$key]['yj_成品数量']-(int)$rows[$key]['包装产量'];
  1163. // }else{
  1164. // $rows[$key]['状态'] = '';
  1165. // $rows[$key]['缺数'] = '';
  1166. // }
  1167. // }
  1168. $data = [
  1169. 'total' => count($data),
  1170. 'rows' => $data,
  1171. ];
  1172. $this->success('成功',$data);
  1173. }
  1174. /**
  1175. * 入仓末板数据统计列表excel导出
  1176. * @ApiMethod (POST)
  1177. * @param string file_name
  1178. * @param array fields
  1179. */
  1180. public function mbExport()
  1181. {
  1182. //get请求
  1183. if(!$this->request->isPost()){
  1184. $this->error('请求方式错误');
  1185. }
  1186. $req = $this->request->param();
  1187. if (!isset($req['file_name'])){
  1188. $this->error('参数错误','file_name');
  1189. }
  1190. if (!(isset($req['fields']) && count($req['fields'])!=0)){
  1191. $this->error('参数错误','fields',100);
  1192. }
  1193. $arr = [
  1194. 'Yj_Gdbh' =>['工单编号'],
  1195. 'yj_Yjno' =>['印件号'],
  1196. 'yj_yjmc' =>['印件名称'],
  1197. 'yj_成品数量' =>['计划交货数量'],
  1198. 'yj_实际投料' =>['印件投料'],
  1199. 'sczl_cls' =>['包装产量'],
  1200. 'jjcp_sj' =>['最近入仓时间'],
  1201. 'jjcp_sls' =>['入仓产量'],
  1202. 'status' =>['完工'],
  1203. '缺数' =>['缺数'],
  1204. ];
  1205. $data[0] = [];
  1206. foreach ($req['fields'] as $k=>$v){
  1207. if(array_key_exists($v,$arr)){
  1208. array_push($data[0],$arr[$v][0]);
  1209. }
  1210. }
  1211. $date = date('Y-m-d',strtotime('-3 month'));
  1212. $arr1 = db('db_包装产量预报')
  1213. ->field('sczl_gdbh1, sczl_gdbh2, sczl_gdbh3, sczl_gdbh4, sczl_gdbh5, sczl_gdbh6,
  1214. cast(substr(sczl_yjGx1,1,2) as signed) as sczl_yjGx1, cast(substr(sczl_yjGx2,1,2) as signed) as sczl_yjGx2,
  1215. cast(substr(sczl_yjGx3,1,2) as signed) as sczl_yjGx3, cast(substr(sczl_yjGx4,1,2) as signed) as sczl_yjGx4,
  1216. cast(substr(sczl_yjGx5,1,2) as signed) as sczl_yjGx5, cast(substr(sczl_yjGx6,1,2) as signed) as sczl_yjGx6,
  1217. (sczl_cl1*sczl_PgCl1+sczl_clAdd1) as sczl_cls1,
  1218. (sczl_cl2*sczl_PgCl2+sczl_clAdd2) as sczl_cls2,
  1219. (sczl_cl3*sczl_PgCl3+sczl_clAdd3) as sczl_cls3,
  1220. (sczl_cl4*sczl_PgCl4+sczl_clAdd4) as sczl_cls4,
  1221. (sczl_cl5*sczl_PgCl5+sczl_clAdd5) as sczl_cls5,
  1222. (sczl_cl6*sczl_PgCl6+sczl_clAdd6) as sczl_cls6
  1223. ')
  1224. ->where('sczl_rq','>=',$date)
  1225. ->select();
  1226. $data1 = [];
  1227. foreach ($arr1 as $k=>$v){
  1228. for ($i=1;$i<=6;$i++){
  1229. if(array_key_exists($v['sczl_gdbh'.$i].'-'.$v['sczl_yjGx'.$i],$data1)){
  1230. $data1[$v['sczl_gdbh'.$i].'-'.$v['sczl_yjGx'.$i]] += $v['sczl_cls'.$i];
  1231. }else{
  1232. $data1[$v['sczl_gdbh'.$i].'-'.$v['sczl_yjGx'.$i]] = $v['sczl_cls'.$i];
  1233. }
  1234. }
  1235. }
  1236. krsort($data1);
  1237. //糊盒成品入仓中jjcp_smb不为空的工单
  1238. $rows1 = db('糊盒成品入仓')
  1239. ->where('jjcp_smb','<>','')
  1240. ->order('jjcp_gdbh desc')
  1241. ->column("CONCAT(jjcp_gdbh, '-', jjcp_yjno) AS gdyj, UniqId");
  1242. $rows2 = db('糊盒成品入仓')
  1243. ->where('jjcp_sj','>=',$date)
  1244. ->group('jjcp_gdbh, jjcp_cpdh')
  1245. ->column("CONCAT( jjcp_gdbh, '-', jjcp_yjno) AS gdyj, jjcp_smb,
  1246. sum(jjcp_sl) as jjcp_sls, left(max(jjcp_sj),10) as jjcp_sj");
  1247. $rows3 = db('工单_印件资料')->cache(true,86400)
  1248. ->group('Yj_Gdbh, yj_Yjno')
  1249. ->column("CONCAT( Yj_Gdbh, '-', yj_Yjno) AS gdyj,
  1250. Yj_Gdbh, yj_Yjno, yj_yjmc, yj_成品数量, yj_实际投料");
  1251. foreach($data1 as $key=>$value){
  1252. if(!array_key_exists($key,$rows1)){
  1253. $subArray = [];
  1254. foreach ($arr as $k=>$v){
  1255. if($k=='yj_成品数量' || $k=='yj_实际投料'){
  1256. if(array_key_exists($key,$rows3)){
  1257. $subArray[$k] = (string)floatval($rows3[$key][$k]*10000);
  1258. }else{
  1259. $subArray[$k] = '';
  1260. }
  1261. }else if($k=='Yj_Gdbh' || $k=='yj_Yjno'){
  1262. if(array_key_exists($key,$rows3)){
  1263. $subArray[$k] = $rows3[$key][$k];
  1264. }else{
  1265. $subArray[$k] = '';
  1266. }
  1267. }else if($k=='yj_yjmc'){
  1268. if(array_key_exists($key,$rows3)){
  1269. $subArray[$k] = trim($rows3[$key][$k]);
  1270. }else{
  1271. $subArray[$k] = '';
  1272. }
  1273. }else if($k=='sczl_cls'){
  1274. $subArray[$k] = (string)floatval($value);
  1275. }else if($k=='status'){
  1276. if(array_key_exists($key,$rows2) && $rows2[$key]['jjcp_smb'] !=''){
  1277. $subArray[$k] = '完工';
  1278. }else{
  1279. $subArray[$k] = '';
  1280. }
  1281. }else if($k=='缺数'){
  1282. if(array_key_exists($key,$rows2) && $rows2[$key]['jjcp_smb'] !=''){
  1283. $subArray[$k]['缺数'] = (int)$rows3[$key]['yj_成品数量']-(int)$value;
  1284. }else{
  1285. $subArray[$k] = '';
  1286. }
  1287. }else{
  1288. if(array_key_exists($key,$rows2)){
  1289. $subArray[$k] = $rows2[$key][$k];
  1290. $subArray[$k] = $rows2[$key][$k];
  1291. $subArray[$k] = $rows2[$key][$k];
  1292. }else{
  1293. $subArray[$k] = '';
  1294. $subArray[$k] = '';
  1295. $subArray[$k] = '';
  1296. }
  1297. }
  1298. }
  1299. array_push($data,$subArray);
  1300. }
  1301. }
  1302. $this->success('成功',['file_name'=>$req['file_name'],'data'=>$data]);
  1303. }
  1304. }