赫艾后端
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

853 lines
47 KiB

4 years ago
3 years ago
3 years ago
3 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
3 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
4 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
3 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
3 years ago
4 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  3. <mapper namespace="com.heai.modules.production.dao.DailyPlanMapper">
  4. <select id="getShopOrderData" resultType="com.heai.modules.production.entity.ShopOrderData" parameterType="com.heai.modules.production.entity.DailyPlanInData">
  5. select a.site, a.OrderNo,a.PartNo,a.Status,a.PlanStartDate,a.NeedDate,a.LotSize,a.EnterDate,a.UserName,
  6. P.PartDescription+'/'+isnull(P.Spec,'') PartDescription,P.Spec,ROUND(ISNULL(so.scheduling_size,0),3) as scheduling_size,dbo.Get_PartWeightFactorForReport(a.site,a.PartNo,a.OrderNo) as weightFactor,
  7. Round(dbo.Get_PartWeightFactorForReport(a.site,a.PartNo,a.OrderNo)*a.LotSize,2) as weight
  8. FROM ShopOrder a
  9. LEFT JOIN Part P ON P.PartNo=a.PartNo AND a.site=P.Site
  10. LEFT JOIN so_scheduled_list so ON a.site=so.Site AND a.OrderNo= so.order_no
  11. <where>
  12. <if test="site != null and site != ''">
  13. AND a.site = #{site}
  14. </if>
  15. <if test="orderNo != null and orderNo != ''">
  16. AND a.OrderNo LIKE #{orderNo}
  17. </if>
  18. <if test="status !=null and status != ''">
  19. AND a.Status IN ${status}
  20. </if>
  21. <if test="startDate1 != null ">
  22. AND a.EnterDate >= #{startDate1}
  23. </if>
  24. <if test="endDate1 != null ">
  25. AND #{endDate1} >= DATEADD(dd, -1, a.EnterDate)
  26. </if>
  27. <if test="startDate2 != null ">
  28. AND a.PlanStartDate >= #{startDate2}
  29. </if>
  30. <if test="endDate2 != null ">
  31. AND #{endDate2} >= a.PlanStartDate
  32. </if>
  33. <if test="startDate3 != null ">
  34. AND a.NeedDate >= #{startDate3}
  35. </if>
  36. <if test="endDate3 != null ">
  37. AND #{endDate3} >= a.NeedDate
  38. </if>
  39. <if test="partNo != null and partNo != ''">
  40. AND a.PartNo LIKE #{partNo}
  41. </if>
  42. <if test="planStatus != null and planStatus != ''">
  43. and ${planStatus}
  44. </if>
  45. AND a.E_Levels=1
  46. </where>
  47. order by a.PlanStartDate
  48. </select>
  49. <select id="getGenerateReportList" resultType="com.heai.modules.production.entity.GenerateReportData">
  50. Select T.Site,T.OrderNo,T.ItemNo,T.OperationDesc,T.WorkCenterNo,W.WorkCenterDesc,T.QtyRequired,T.QtyReported
  51. ,T.QtyApprove ,T.TimeRequired,T.TimeReported,T.PlanStartTime,T.PlanFinishTime
  52. ,T.ClosedFlag,T.PartNo,P.PartDescription,P.Spec,D.NeedDate,D.PlanStartDate,D.Status
  53. ,D.LotSize,D.FinishedQty
  54. from SORouting as T,ShopOrder as D,WorkCenter as W,Part as P
  55. <where>
  56. T.Site=D.Site and T.OrderNo=D.OrderNo and T.Site=W.Site and T.WorkCenterNo=W.WorkCenterNo
  57. and D.Site=P.Site and D.PartNo=P.PartNo
  58. <if test="site != null and site != ''">
  59. and T.site = #{site,jdbcType=VARCHAR}
  60. </if>
  61. <if test="workCenterNo != null and workCenterNo != ''">
  62. and T.WorkCenterNo like '%' + #{workCenterNo,jdbcType=VARCHAR} + '%'
  63. </if>
  64. <if test="partNo != null and partNo != ''">
  65. and T.PartNo like '%' + #{partNo,jdbcType=VARCHAR} + '%'
  66. </if>
  67. <if test="orderNo != null and orderNo != ''">
  68. and T.OrderNo like '%' + #{orderNo,jdbcType=VARCHAR} + '%'
  69. </if>
  70. </where>
  71. </select>
  72. <select id="getShopOrderForHunlian" resultType="com.heai.modules.production.entity.ShopOrderData">
  73. select A.OrderNo ,A.Site ,A.EnterDate ,A.UserName ,A.NeedDate ,A.OriginalNeedDate ,A.PlanStartDate ,A.ReleaseDate
  74. ,A.ReleaseGuys ,A.ScheduleDate ,A.Scheduler ,A.IssueDate ,A.ReportDate ,A.ReceiveDate ,A.CloseDate
  75. ,A.Planner ,A.Status ,A.Status_Tmp ,A.Printed ,A.OrderType ,A.PartNo ,A.LotSize ,A.FinishedQty
  76. ,A.ProjectID ,A.BOMRevNo ,A.RoutingRevNo ,A.Leadtime ,A.Remark ,A.OrderRef1 ,A.OrderRef2 ,A.CostRollUpFlag
  77. ,A.ManualFlag ,A.OriSOOrderNo ,A.CustomerID ,A.TechInfo ,A.ReceiveStatus ,A.E_OriginalOrderNo
  78. ,A.E_Levels ,A.E_OriginalOrderType ,A.E_SeqNo ,A.E_LevelCode ,A.SFDCReportedFlag ,A.RepairSOFlag
  79. ,A.ConfigurationFlag ,A.MaterialSplitFlag ,A.ObjectVersion ,A.ExpandFlag ,A.CodeNo ,A.LE_SeqNo
  80. ,A.LE_ItemNo ,A.LE_Levels
  81. ,B.PartDescription,dbo.Get_PartWeightFactorForReport(A.Site ,A.PartNo,A.OrderNo) as weightFactor,
  82. Round(dbo.Get_PartWeightFactorForReport(A.Site ,A.PartNo,A.OrderNo)*A.LotSize,2) weight
  83. from ShopOrder A
  84. left join Part B on A.site = B.site and A.PartNo = B.PartNo
  85. <where>
  86. and A.E_Levels=2
  87. <if test="site != null and site != ''">
  88. and A.Site = #{site,jdbcType=VARCHAR}
  89. </if>
  90. <if test="orderNo != null and orderNo != ''">
  91. and A.OrderNo = #{orderNo,jdbcType=VARCHAR}
  92. </if>
  93. </where>
  94. </select>
  95. <select id="getHunlianTaskHeader" resultType="com.heai.modules.production.entity.HunlianData">
  96. select Site,TaskNo,orderRef1 from Hunlian_TaskHeader where DeleteFlag='N' and TaskNo=#{taskNo}
  97. </select>
  98. <select id="getShopOrderList" resultType="com.heai.modules.production.entity.ShopOrderData">
  99. select A.OrderNo ,A.Site ,A.EnterDate ,A.UserName ,A.NeedDate ,A.OriginalNeedDate ,A.PlanStartDate ,A.ReleaseDate
  100. ,A.ReleaseGuys ,A.ScheduleDate ,A.Scheduler ,A.IssueDate ,A.ReportDate ,A.ReceiveDate ,A.CloseDate
  101. ,A.Planner ,A.Status ,A.Status_Tmp ,A.Printed ,A.OrderType ,A.PartNo ,A.LotSize ,A.FinishedQty
  102. ,A.ProjectID ,A.BOMRevNo ,A.RoutingRevNo ,A.Leadtime ,A.Remark ,A.OrderRef1 ,A.OrderRef2 ,A.CostRollUpFlag
  103. ,A.ManualFlag ,A.OriSOOrderNo ,A.CustomerID ,A.TechInfo ,A.ReceiveStatus ,A.E_OriginalOrderNo
  104. ,A.E_Levels ,A.E_OriginalOrderType ,A.E_SeqNo ,A.E_LevelCode ,A.SFDCReportedFlag ,A.RepairSOFlag
  105. ,A.ConfigurationFlag ,A.MaterialSplitFlag ,A.ObjectVersion ,A.ExpandFlag ,A.CodeNo ,A.LE_SeqNo
  106. ,A.LE_ItemNo ,A.LE_Levels
  107. ,B.PartDescription
  108. from ShopOrder A
  109. left join Part B on A.site = B.site and A.PartNo = B.PartNo
  110. <where>
  111. <if test="site != null and site != ''">
  112. and A.Site = #{site,jdbcType=VARCHAR}
  113. </if>
  114. <if test="orderNo != null and orderNo != ''">
  115. and A.OrderNo = #{orderNo,jdbcType=VARCHAR}
  116. </if>
  117. </where>
  118. </select>
  119. <select id="getTransfer" resultType="com.heai.modules.production.entity.ShopOrderData">
  120. select a.TransNo as transFerNo ,b.PartNo,c.PartDescription,a.Status,b.TransQty as lotSize,b.ConfirmQty as FinishedQty,a.Site, b.OrderNo,dbo.Get_PartWeightFactorForReport(A.Site ,b.PartNo,b.OrderNo) as weightFactor,
  121. dbo.Get_Part_DefaultWarehouseID(a.Site,b.PartNo) DefaultWarehouseID,b.seqNo,a.needReceiveFlag,Round(isnull(b.boxWeight,0),2) boxWeight
  122. from SOOpsTransferHeader a left join SOOpsTransferDetail b on a.TransNo=b.TransNo and a.Site=b.Site
  123. LEFT JOIN Part c on b.partNo=c.partNo and c.site=a.site
  124. <where>
  125. <if test="transFerNo != null and transFerNo != ''">
  126. and a.TransNo = #{transFerNo}
  127. </if>
  128. </where>
  129. </select>
  130. <select id="checkShopOrderStatus" resultType="com.heai.modules.production.entity.ShopOrderData">
  131. select orderNo,status from shopOrder where Site=#{site} and OrderNo=#{orderNo}
  132. </select>
  133. <select id="getOperatorData" resultType="com.heai.modules.production.entity.OperatorData" >
  134. select Site,OperatorID,OperatorName,Active,Department,CreatedDate,Passwords,LineLeader
  135. from Operator
  136. <where>
  137. <if test="site != null and site != ''">
  138. and Site = #{site}
  139. </if>
  140. <if test="operatorID != null and operatorID != ''">
  141. and OperatorID like #{operatorID,jdbcType=VARCHAR}
  142. </if>
  143. <if test="operatorName != null and operatorName != ''">
  144. and OperatorName like #{operatorName}
  145. </if>
  146. <if test="active != null and active != ''">
  147. and Active = #{active}
  148. </if>
  149. </where>
  150. order by CreatedDate
  151. </select>
  152. <select id="getWorkCenterData" resultType="WorkCenterData">
  153. select a.Site,a.WorkCenterNo,a.WorkCenterDesc,a.Active FROM WorkCenter a left join
  154. operator_work_center b on a.Site=b.Site and a.WorkCenterNo=b.WorkCenterNo and b.OperatorID=#{operatorID}
  155. where a.site=#{site} and b.WorkCenterNo is null
  156. order by a.WorkCenterNo
  157. </select>
  158. <select id="getWorkCenterOperatorData" resultType="WorkCenterData">
  159. select a.Site,a.WorkCenterNo,b.WorkCenterDesc,b.Active FROM operator_work_center a left join
  160. WorkCenter b on a.Site=b.Site and a.WorkCenterNo=b.WorkCenterNo
  161. where a.site=#{site} and a.OperatorID=#{operatorID}
  162. order by a.WorkCenterNo
  163. </select>
  164. <insert id="addSkill">
  165. insert into operator_work_center(OperatorID,WorkCenterNo,created_by,created_date,Site)
  166. values(#{operatorID},#{workCenterNo},#{user},GetDate(),#{site})
  167. </insert>
  168. <delete id="deleteSkill">
  169. delete from operator_work_center where OperatorID=#{operatorID} and Site=#{site} and WorkCenterNo=#{workCenterNo}
  170. </delete>
  171. <insert id="addUserSkill">
  172. insert into user_work_center(UserId,WorkCenterNo,created_by,created_date,Site)
  173. values(#{userId},#{workCenterNo},#{user},GetDate(),#{site})
  174. </insert>
  175. <delete id="deleteUserSkill">
  176. delete from user_work_center where UserId=#{userId} and Site=#{site} and WorkCenterNo=#{workCenterNo}
  177. </delete>
  178. <select id="checkWorkCenterOperatorData" resultType="WorkCenterData">
  179. select site FROM operator_work_center where OperatorID=#{operatorID} and Site=#{site} and WorkCenterNo=#{workCenterNo}
  180. </select>
  181. <select id="checkUserOperatorData" resultType="WorkCenterData">
  182. select site FROM user_work_center where userId=#{userId} and Site=#{site} and WorkCenterNo=#{workCenterNo}
  183. </select>
  184. <select id="getAllWorkCenterDataForUser" resultType="WorkCenterData">
  185. select a.Site,a.WorkCenterNo,a.WorkCenterDesc,a.Active FROM WorkCenter a left join
  186. user_work_center b on a.Site=b.Site and a.WorkCenterNo=b.WorkCenterNo and b.userId=#{user}
  187. where b.WorkCenterNo is null
  188. order by a.WorkCenterNo ,a.site
  189. </select>
  190. <select id="getWorkCenterUserData" resultType="WorkCenterData">
  191. select a.Site,a.WorkCenterNo,b.WorkCenterDesc,b.Active FROM user_work_center a left join
  192. WorkCenter b on a.Site=b.Site and a.WorkCenterNo=b.WorkCenterNo
  193. where a.userId=#{user}
  194. order by a.WorkCenterNo,a.site
  195. </select>
  196. <select id="getShopOrderRoutingData" resultType="ShopOrderRoutingData">
  197. select a.site, a.OrderNo,a.PartNo,a.Status,a.PlanStartDate,a.NeedDate,a.LotSize,a.EnterDate,a.UserName,
  198. P.PartDescription+'/'+isnull(P.Spec,'') PartDescription,P.Spec,isnull(SL.scheduledQty,0) as scheduledQty,s.workCenterNo,S.qtyReported,S.qtyApprove,S.machSetupTime,
  199. S.machRunFactor,S.factorUnit,S.ItemNo,S.OperationDesc,s.Efficiency,isnull(SOP.TotalFinishedQty,0) lastApproveQty,dbo.Get_PartWeightFactorForReport(a.site,a.PartNo,a.OrderNo) weightFactor,
  200. Round(dbo.Get_PartWeightFactorForReport(a.site,a.PartNo,a.OrderNo)*a.LotSize,2) weight,dbo.Get_PartPlanQty(a.site,a.PartNo,a.OrderNo) partPlanQty
  201. FROM ShopOrder a
  202. LEFT JOIN Part P ON P.PartNo=a.PartNo AND a.site=P.Site
  203. LEFT JOIN SORouting S on S.site=a.site and S.OrderNo=a.orderNo
  204. LEFT JOIN ScheduleList SL on S.site=SL.site and S.OrderNo=SL.orderNo and S.ItemNo=SL.ItemNo
  205. LEFT JOIN SORoutingOutput SOP ON a.site=SOP.site and a.OrderNo=SOP.OrderNo and SOP.itemNo=dbo.Get_SORouting_PreviousOperationItemNo(a.site,a.OrderNo,S.itemNo)
  206. left join user_work_center uwc on a.site=uwc.site and s.workCenterNo =uwc.WorkCenterNo and uwc.userId=#{userId}
  207. <where>
  208. and uwc.WorkCenterNo is not null
  209. and a.E_Levels =0
  210. <if test="site != null and site != ''">
  211. AND a.site = #{site}
  212. </if>
  213. <if test="orderNo != null and orderNo != ''">
  214. AND a.OrderNo LIKE #{orderNo}
  215. </if>
  216. <!-- <if test="status !=null and status != ''">-->
  217. <!-- AND a.Status IN ${status}-->
  218. <!-- </if>-->
  219. <if test="startDate1 != null ">
  220. AND a.EnterDate >= #{startDate1}
  221. </if>
  222. <if test="endDate1 != null ">
  223. AND #{endDate1} >= DATEADD(dd, -1, a.EnterDate)
  224. </if>
  225. <if test="startDate2 != null ">
  226. AND a.PlanStartDate >= #{startDate2}
  227. </if>
  228. <if test="endDate2 != null ">
  229. AND #{endDate2} >= a.PlanStartDate
  230. </if>
  231. <if test="startDate3 != null ">
  232. AND a.NeedDate >= #{startDate3}
  233. </if>
  234. <if test="endDate3 != null ">
  235. AND #{endDate3} >= a.NeedDate
  236. </if>
  237. <if test="partNo != null and partNo != ''">
  238. AND a.PartNo LIKE #{partNo}
  239. </if>
  240. <if test="planStatus != null and planStatus != ''">
  241. and ${planStatus}
  242. </if>
  243. <if test="itemNo != null and itemNo != ''">
  244. and S.ItemNo = #{itemNo}
  245. </if>
  246. <if test="eLevels != null ">
  247. and a.E_Levels = #{eLevels}
  248. </if>
  249. </where>
  250. order by a.PlanStartDate desc,s.itemNo
  251. </select>
  252. <select id="getSOTastRoutingData" resultType="ShopOrderRoutingData">
  253. select a.site, a.OrderNo,a.PartNo,a.Status,a.OrderRef1,a.OrderDate,a.OrderQty as LotSize,
  254. P.PartDescription+'/'+isnull(P.Spec,'') PartDescription,P.Spec,isnull(SL.scheduledQty,0) as scheduledQty,s.workCenterNo,S.machSetupTime,
  255. S.machRunFactor,S.factorUnit,S.ItemNo,S.OperationDesc,s.Efficiency,a.qtyfinished,a.finishFlag,ROUND(dbo.Get_PartWeightFactorForReport(a.site,a.PartNo,a.OrderRef1)*a.OrderQty,2) as weight,
  256. dbo.Get_PartWeightFactorForReport(a.site,a.PartNo,a.OrderRef1) as weightFactor,dbo.Get_PartPlanQty(a.site,a.PartNo,a.OrderRef1) partPlanQty
  257. FROM SOTaskOrderHeader a
  258. LEFT JOIN Part P ON P.PartNo=a.PartNo AND a.site=P.Site
  259. LEFT JOIN SORouting S on S.site=a.site and S.OrderNo=a.OrderRef1
  260. LEFT JOIN ScheduleList SL on S.site=SL.site and a.OrderNo=SL.orderNo and S.ItemNo=SL.ItemNo
  261. left join user_work_center uwc on a.site=uwc.site and s.workCenterNo =uwc.WorkCenterNo and uwc.userId=#{userId}
  262. <where>
  263. and uwc.WorkCenterNo is not null
  264. <if test="site != null and site != ''">
  265. AND a.site = #{site}
  266. </if>
  267. <if test="orderNo != null and orderNo != ''">
  268. AND a.OrderNo LIKE #{orderNo}
  269. </if>
  270. <if test="status !=null and status != ''">
  271. AND a.Status IN ${status}
  272. </if>
  273. <if test="startDate1 != null ">
  274. AND a.orderDate >= #{startDate1}
  275. </if>
  276. <if test="endDate1 != null ">
  277. AND #{endDate1} >= a.orderDate
  278. </if>
  279. <if test="orderRef1 != null and orderRef1 != ''">
  280. AND a.OrderRef1 LIKE #{orderRef1}
  281. </if>
  282. <if test="partNo != null and partNo != ''">
  283. AND a.PartNo LIKE #{partNo}
  284. </if>
  285. <if test="planStatus != null and planStatus != ''">
  286. and ${planStatus}
  287. </if>
  288. <if test="itemNo != null and itemNo != ''">
  289. and S.ItemNo = #{itemNo}
  290. </if>
  291. <if test="finishFlag != null and finishFlag != ''">
  292. AND a.FinishFlag=#{finishFlag}
  293. </if>
  294. </where>
  295. order by a.OrderDate desc,s.itemNo
  296. </select>
  297. <select id="getWorkCenterOperatorList" resultType="OperatorData">
  298. Select a.OperatorID,a.OperatorName from Operator a left join operator_work_center b on a.site=b.site and a.OperatorID=b.OperatorID
  299. where a.site=#{site} and b.WorkCenterNo=#{workCenterNo} and a.Active='Y'
  300. </select>
  301. <select id="checkScheduleQty" resultType="ScheduleCheckData">
  302. Select a.lotSize as Qty,isnull(b.scheduledQty,0) scheduledQty from ShopOrder a left join ScheduleList b on a.site=b.site and a.orderNo=b.orderNo and b.itemNo=#{itemNo} where a.Site=#{site} and a.OrderNo=#{orderNo}
  303. </select>
  304. <select id="checkScheduleQtyForSoTask" resultType="ScheduleCheckData">
  305. Select a.OrderQty as Qty,isnull(b.scheduledQty,0) scheduledQty from SOTaskOrderHeader a left join ScheduleList b on a.site=b.site and a.orderNo=b.orderNo and b.itemNo=#{itemNo} where a.Site=#{site} and a.OrderNo=#{orderNo}
  306. </select>
  307. <select id="checkScheduleList" resultType="ScheduleCheckData">
  308. Select Qty from ScheduleList where Site=#{site} and OrderNo=#{orderNo} and itemNo=#{itemNo}
  309. </select>
  310. <insert id="saveScheduleList">
  311. insert into ScheduleList(Site,OrderNo,ItemNo,Type,Type_db,Qty,scheduledQty) values (#{site},#{orderNo},#{itemNo},'生产订单派工单','S',#{qty},0)
  312. </insert>
  313. <insert id="saveScheduleListForSOTask">
  314. insert into ScheduleList(Site,OrderNo,ItemNo,Type,Type_db,Qty,scheduledQty) values (#{site},#{orderNo},#{itemNo},'日计划派工单','D',#{qty},0)
  315. </insert>
  316. <select id="getDataSequence" resultType="integer">
  317. select seqNo from DataSequence where SeqType= 'A'
  318. </select>
  319. <update id="updateDataSequence">
  320. update DataSequence set seqNo=seqNo+1 where SeqType= 'A'
  321. </update>
  322. <insert id="saveSchedule">
  323. Insert into soscheduledrouting(Site,OrderNo,ItemNo,SeqNo,QtyRequired,QtyReported,QtyApprove,TimeRequired,TimeReported,PlanStartTime,PlanFinishTime
  324. ,BarcodeID,Remark,Crewsize,ClosedFlag,QtyScrapt,OutWorkFlag,S_ScheduledDate,S_ResourceID,S_ShiftNo,S_WorkCenterNo
  325. ,SelectedFlag,SourceFlag,ParkFlag,TimeRequired_Original,QtyRequired_Original
  326. ,StartProdFlag,CancelledProdFlag,Efficiency,EnteredDate,scheduleType,operatorId,partNo,OrderRef1,cancelReportFlag,CreateBy)
  327. values(#{site},#{orderNo},#{itemNo},#{seqNo},#{scheduleQty},0,0,dbo.Get_SOScheduleRouting_TimeRequired(#{site},#{orderNo},#{itemNo},#{scheduleQty}),0,#{scheduleDate},#{scheduleDate}
  328. ,'*',#{remark},1,'N',0,'Y',#{scheduleDate},#{resourceId},#{shiftNo},#{workCenterNo}
  329. ,'N','N','N',dbo.Get_SOScheduleRouting_TimeRequired(#{site},#{orderNo},#{itemNo},#{scheduleQty}),#{scheduleQty}
  330. ,'N','N',#{efficiency},GETDATE(),'生产订单派工单',#{operatorId},#{partNo},#{orderNo},'N',#{createBy})
  331. </insert>
  332. <insert id="saveScheduleForSOTask">
  333. Insert into soscheduledrouting(Site,OrderNo,ItemNo,SeqNo,QtyRequired,QtyReported,QtyApprove,TimeRequired,TimeReported,PlanStartTime,PlanFinishTime
  334. ,BarcodeID,Remark,Crewsize,ClosedFlag,QtyScrapt,OutWorkFlag,S_ScheduledDate,S_ResourceID,S_ShiftNo,S_WorkCenterNo
  335. ,SelectedFlag,SourceFlag,ParkFlag,TimeRequired_Original,QtyRequired_Original
  336. ,StartProdFlag,CancelledProdFlag,Efficiency,EnteredDate,scheduleType,operatorId,partNo,OrderRef1,cancelReportFlag,CreateBy)
  337. values(#{site},#{orderRef1},#{itemNo},#{seqNo},#{scheduleQty},0,0,dbo.Get_SOScheduleRouting_TimeRequired(#{site},#{orderRef1},#{itemNo},#{scheduleQty}),0,#{scheduleDate},#{scheduleDate}
  338. ,'*',#{remark},1,'N',0,'Y',#{scheduleDate},#{resourceId},#{shiftNo},#{workCenterNo}
  339. ,'N','N','N',dbo.Get_SOScheduleRouting_TimeRequired(#{site},#{orderRef1},#{itemNo},#{scheduleQty}),#{scheduleQty}
  340. ,'N','N',#{efficiency},GETDATE(),'日计划派工单',#{operatorId},#{partNo},#{orderNo},'N',#{createBy})
  341. </insert>
  342. <update id="updateScheduleListQty">
  343. update ScheduleList set scheduledQty=scheduledQty+#{sumQty} where Site=#{site} and OrderNo=#{orderNo} and itemNo=#{itemNo} and type=#{scheduleType}
  344. </update>
  345. <select id="searchReportedQty" resultType="SORoutingData">
  346. select top 1 isnull(a.QtyReported,0) QtyReported,isnull(SOP.TotalFinishedQty,0) lastApproveQty ,dbo.Get_PartWeightFactorForReport(#{site},#{partNo},#{orderNo}) as weightFactor,dbo.Get_sfdcReportedSetupTime(#{site},#{seqNo}) as timeReported,
  347. [dbo].[Get_Part_Cavity](#{site},#{partNo},#{orderNo}) as cavity
  348. from SORouting a
  349. LEFT JOIN SORoutingOutput SOP ON a.site=SOP.site and a.OrderNo=SOP.OrderNo and SOP.itemNo=dbo.Get_SORouting_PreviousOperationItemNo(a.site,a.OrderNo,a.itemNo)
  350. where a.Site=#{site} and a.OrderNo=#{orderNo} and a.itemNo=#{itemNo}
  351. </select>
  352. <select id="searchLastApproveQty" resultType="SORoutingData">
  353. select top 1 isnull(TotalFinishedQty,0) lastApproveQty from SORoutingOutput where Site=#{site} and OrderNo=#{orderNo} and itemNo=dbo.Get_SORouting_PreviousOperationItemNo(#{site},#{orderNo},#{itemNo})
  354. </select>
  355. <select id="getSOScheduleRoutingDataForShiyanshi" resultType="SOScheduledRoutingOutData">
  356. select a.Site,OrderNo,ItemNo,SeqNo,QtyRequired,QtyReported,QtyApprove,TimeRequired,TimeReported,
  357. BarcodeID,Remark,Crewsize,ClosedFlag,S_ScheduledDate,S_ResourceID,S_ScheduledSeqNo,S_ShiftNo,
  358. S_WorkCenterNo, EnteredDate,scheduleType,operatorId,partNo,dbo.Get_Part_DescSpec(a.Site,partNo) as partDesc,
  359. dbo.Get_OperatorDesc(a.Site,operatorId) as operatorName,dbo.Get_ItemDesc(a.Site,OrderNo,ItemNo) as itemDesc,orderRef1 ,
  360. dbo.Get_WorkCenterDesc(a.Site,S_WorkCenterNo) as workCenterDesc , dbo.Get_Part_DescSpec(a.Site,partNo) as partSpec,circulation_seqNo,circulation_qty
  361. ,dbo.Get_PartWeightFactorForReport(a.site,PartNo,OrderNo) as weightFactor,dbo.Get_Part_UMID(a.Site,PartNo) umid,
  362. Round(dbo.Get_PartWeightFactorForReport(a.site,PartNo,OrderNo)*QtyRequired,2) as weight from SOScheduledRouting a
  363. <where>
  364. <if test="seqNo != null and seqNo != ''">
  365. AND a.seqNo = #{seqNo}
  366. </if>
  367. <if test="site != null and site != ''">
  368. AND a.site = #{site}
  369. </if>
  370. </where>
  371. order by S_ScheduledDate
  372. </select>
  373. <select id="getSOScheduleRoutingData" resultType="SOScheduledRoutingOutData">
  374. select a.Site,OrderNo,ItemNo,SeqNo,QtyRequired,QtyReported,QtyApprove,TimeRequired,TimeReported,
  375. BarcodeID,Remark,Crewsize,ClosedFlag,S_ScheduledDate,S_ResourceID,S_ScheduledSeqNo,S_ShiftNo,
  376. S_WorkCenterNo, EnteredDate,scheduleType,operatorId,partNo,dbo.Get_Part_DescSpec(a.Site,partNo) as partDesc,
  377. dbo.Get_OperatorDesc(a.Site,operatorId) as operatorName,dbo.Get_ItemDesc(a.Site,OrderNo,ItemNo) as itemDesc,orderRef1 ,
  378. dbo.Get_WorkCenterDesc(a.Site,S_WorkCenterNo) as workCenterDesc , dbo.Get_Part_DescSpec(a.Site,partNo) as partSpec,circulation_seqNo,circulation_qty
  379. ,dbo.Get_PartWeightFactorForReport(a.site,PartNo,OrderNo) as weightFactor,dbo.Get_Part_UMID(a.Site,PartNo) umid,
  380. Round(dbo.Get_PartWeightFactorForReport(a.site,PartNo,OrderNo)*QtyRequired,2) as weight from SOScheduledRouting a
  381. left join user_work_center uwc on a.site=uwc.site and a.S_WorkCenterNo =uwc.WorkCenterNo and uwc.userId=#{userId}
  382. <where>
  383. and uwc.WorkCenterNo is not null
  384. <if test="site != null and site != ''">
  385. AND a.site = #{site}
  386. </if>
  387. <if test="orderNo != null and orderNo != ''">
  388. AND OrderNo LIKE #{orderNo}
  389. </if>
  390. <if test="partNo != null and partNo != ''">
  391. AND PartNo LIKE #{partNo}
  392. </if>
  393. <if test="sWorkCenterNo != null and sWorkCenterNo != ''">
  394. AND S_WorkCenterNo LIKE #{sWorkCenterNo}
  395. </if>
  396. <if test="itemNo != null and itemNo != ''">
  397. and ItemNo = #{itemNo}
  398. </if>
  399. <if test="itemDesc != null and itemDesc != ''">
  400. and dbo.Get_ItemDesc(a.Site,OrderNo,ItemNo) = #{itemDesc}
  401. </if>
  402. <if test="closedFlag != null and closedFlag != ''">
  403. and ClosedFlag = #{closedFlag}
  404. </if>
  405. <if test="startDate != null ">
  406. and S_ScheduledDate >= #{startDate}
  407. </if>
  408. <if test="endDate != null ">
  409. and #{endDate} >= S_ScheduledDate
  410. </if>
  411. <if test="scheduleType != null and scheduleType != ''">
  412. and scheduleType = #{scheduleType}
  413. </if>
  414. <if test="reportFlag != null and reportFlag != ''">
  415. and ${reportFlag}
  416. </if>
  417. <if test="operatorName != null and operatorName != ''">
  418. and dbo.Get_OperatorDesc(a.Site,operatorId) like #{operatorName}
  419. </if>
  420. <if test="sResourceID != null and sResourceID != ''">
  421. and S_ResourceID like #{sResourceID}
  422. </if>
  423. <if test="sShiftNo != null and sShiftNo != ''">
  424. and S_ShiftNo = #{sShiftNo}
  425. </if>
  426. </where>
  427. order by S_ScheduledDate
  428. </select>
  429. <select id="checkUserSeqNo" resultType="SOScheduledRoutingOutData">
  430. select seqNo ,CancelReportFlag,a.site,a.OrderNo,a.ItemNo,a.QtyRequired,a.S_WorkCenterNo,a.operatorId,a.partNo from SOScheduledRouting a
  431. left join user_work_center uwc on a.site=uwc.site and a.S_WorkCenterNo =uwc.WorkCenterNo and uwc.userId=#{userId}
  432. where seqNo=#{seqNo} and uwc.WorkCenterNo is not null
  433. </select>
  434. <select id="getStockPrint" resultType="com.heai.modules.production.entity.StockPrintData">
  435. select TransNo,Site,WareHouseId,BatchNo,LocationId,PartNo,OrderNo,TransDate,Qty,PrintFlag,dbo.Get_PartDesc(Site,PartNo) as partDesc
  436. ,dbo.Get_WareHouseDesc(Site,WareHouseId) as wareHouseDesc,dbo.Get_Part_UMID(Site,PartNo) umid
  437. from StockPrint
  438. <where>
  439. <if test="startDate != null ">
  440. and TransDate >= #{startDate}
  441. </if>
  442. <if test="endDate != null ">
  443. and #{endDate} >= TransDate -1
  444. </if>
  445. <if test="site != null and site != ''">
  446. AND site = #{site}
  447. </if>
  448. <if test="orderNo != null and orderNo != ''">
  449. AND orderNo LIKE #{orderNo}
  450. </if>
  451. <if test="seqNo != null and seqNo != ''">
  452. AND seqNo = #{seqNo}
  453. </if>
  454. <if test="printFlag != null and printFlag != ''">
  455. AND printFlag = #{printFlag}
  456. </if>
  457. <if test="partNo != null and partNo != ''">
  458. AND PartNo LIKE #{partNo}
  459. </if>
  460. </where>
  461. order by TransDate desc
  462. </select>
  463. <update id="updatePrintStock">
  464. update StockPrint set PrintFlag='Y' where Site=#{site} and TransNo=#{transNo}
  465. </update>
  466. <update id="updatePrintInfo">
  467. update print_info set status='Y' where Site=#{site} and orderref1=#{transNo}
  468. </update>
  469. <select id="searchSeqNo" resultType="SOScheduledRoutingOutData">
  470. select top 1 Site,OrderNo,ItemNo,SeqNo,QtyRequired,QtyReported,QtyApprove,TimeRequired,TimeReported,
  471. BarcodeID,Remark,Crewsize,ClosedFlag,S_ScheduledDate,S_ResourceID,S_ScheduledSeqNo,S_ShiftNo,
  472. S_WorkCenterNo, EnteredDate,scheduleType,operatorId,partNo,dbo.Get_PartDesc(Site,partNo) as partDesc,
  473. dbo.Get_OperatorDesc(Site,operatorId) as operatorName,dbo.Get_ItemDesc(site,orderNo,ItemNo) as itemDesc,orderRef1 ,
  474. dbo.Get_WorkCenterDesc(Site,S_WorkCenterNo) as workCenterDesc , dbo.Get_Part_DescSpec(Site,partNo) as partSpec,closedFlag,outWorkFlag,ParkFlag,CancelReportFlag
  475. from SOScheduledRouting
  476. where site=#{site} and SeqNo=#{seqNo}
  477. </select>
  478. <select id="checkELevels" resultType="Integer">
  479. select isnull(E_Levels,-1) E_Levels from shoporder where site=#{site} and orderNo=#{orderNo}
  480. </select>
  481. <select id="checkReceiveFlag" resultType="com.heai.modules.production.entity.SOOpsTransferData">
  482. select a.TransNo from SOOpsTransferHeader a left join SOOpsTransferDetail b on a.site=b.site and a.TransNo=b.TransNo
  483. where a.site=#{site} and b.seqNo=#{seqNo} and a.Status='已录入' and a.NeedReceiveFlag='Y' and a.ToTypeFlag_DB='W'
  484. </select>
  485. <select id="checkNotInspectTransFer" resultType="com.heai.modules.production.entity.SOOpsTransferData">
  486. select a.TransNo from SOOpsTransferHeader a left join SOOpsTransferDetail b on a.site=b.site and a.TransNo=b.TransNo
  487. where a.site=#{site} and b.seqNo=#{seqNo} and a.Status='已录入' and a.NeedReceiveFlag='Y' and a.ToTypeFlag_DB='I'
  488. </select>
  489. <select id="getSOScheduledRoutingOutData" resultType="SOScheduledRoutingOutData">
  490. select Site,OrderNo,seqNo from SOScheduledRouting where seqNo=#{seqNo}
  491. </select>
  492. <select id="getsfdcTimeHistData" resultType="com.heai.modules.production.entity.SfdcTimeHistData">
  493. select top 1 site,OrderNo,ItemNo,SeqNo,#{username} as Enteredby ,ClosedFlag,OutWorkFlag from SOScheduledRouting where site=#{site} and SeqNo=#{seqNo} and ClosedFlag='N'
  494. </select>
  495. <select id="getSeqNoSite" resultType="String">
  496. select site from SOScheduledRouting where SeqNo=#{seqNo}
  497. </select>
  498. <select id="checkSfdcTimeHistData" resultType="com.heai.modules.production.entity.SfdcTimeHistData">
  499. select site,OrderNo,ItemNo,SeqNo from SFDC_TimeHist where site=#{site} and seqNo=#{seqNo} and EventDesc='开始生产' and CompletedFlag='N'
  500. </select>
  501. <select id="getHistSeqNo" resultType="Integer">
  502. select isnull(max(HistSeqNo),0)+1 from SFDC_TimeHist where site=#{site} and seqNo=#{seqNo}
  503. </select>
  504. <update id="updateSfdcTimeHistDataContinue" >
  505. Update SFDC_TimeHist set CompletedFlag='Y' ,TillTime=GETDATE(),TillEnteredTime=GETDATE(),TillEnteredBy=#{enteredby},TotalTime=Round(datediff(mi,EventTime,GETDATE())/60.0,2) where SeqNo=#{seqNo,jdbcType=INTEGER} and Site=#{site} and CompletedFlag='N' and EventDesc='暂停生产'
  506. </update>
  507. <update id="updateStopWork" >
  508. update SOScheduledRouting set OutWorkFlag=#{flag} where Site=#{site} and seqNo=#{seqNo}
  509. </update>
  510. <insert id="saveSfdcTimeHistDataStart">
  511. insert into SFDC_TimeHist (Site,OrderNo,ItemNo,SeqNo,HistSeqNo,EventTime,Enteredby,EventDesc,DowntimeCode,EventType,LinkHistSeqNo,TillTime,TillEnteredTime,
  512. TillEnteredBy,CompletedFlag,TotalTime,DowntimePhaseIn,RollNo) values
  513. (#{site},#{orderNo},#{itemNo},#{seqNo},#{histSeqNo},GetDate(),#{enteredby},'开始生产','','P',null,null,null,null,'N',0,'','*')
  514. </insert>
  515. <insert id="saveSfdcTimeHistDataStop">
  516. insert into SFDC_TimeHist (Site,OrderNo,ItemNo,SeqNo,HistSeqNo,EventTime,Enteredby,EventDesc,DowntimeCode,EventType,LinkHistSeqNo,TillTime,TillEnteredTime,
  517. TillEnteredBy,CompletedFlag,TotalTime,DowntimePhaseIn,RollNo) values
  518. (#{site},#{orderNo},#{itemNo},#{seqNo},#{histSeqNo},GetDate(),#{enteredby},'暂停生产','','D',null,null,null,null,'N',0,'','*')
  519. </insert>
  520. <select id="getOldSOScheduledRoutingOutData" resultType="SOScheduledRoutingOutData">
  521. select Site,OrderNo,ItemNo,SeqNo,QtyRequired,QtyReported,QtyApprove,TimeRequired,TimeReported,PlanStartTime,PlanFinishTime,
  522. BarcodeID,Remark,Crewsize,ClosedFlag,QtyScrapt,OutWorkFlag,S_ScheduledDate,S_ResourceID,S_ScheduledSeqNo,S_ShiftNo,
  523. S_WorkCenterNo,ParkFlag,TimeRequired_Original,QtyRequired_Original,QtyReturntoSchedule,StartProdFlag,CancelledProdFlag,
  524. Efficiency,EnteredDate,SelectedFlag,SourceFlag,Closedby,ClosedDate,VirtualResourceFlag,mat_issueflag,plate_issueflag,
  525. tool_issueflag,scheduleType,operatorId,partNo,orderRef1,circulation_seqNo,circulation_qty from SOScheduledRouting where
  526. site=#{site} and seqNo=#{seqNo}
  527. </select>
  528. <update id="closeOldSchedule">
  529. update SOScheduledRouting set ClosedFlag='Y',circulation_seqNo=#{newSeqNo},circulation_qty=#{circulationQty} where site=#{site} and seqNo=#{oldSeqNo}
  530. </update>
  531. <insert id="saveCirculationSchedule" >
  532. INSERT into SOScheduledRouting (Site,OrderNo,ItemNo,SeqNo,QtyRequired,QtyReported,QtyApprove,TimeRequired,TimeReported,PlanStartTime,PlanFinishTime,
  533. BarcodeID,Remark,Crewsize,ClosedFlag,QtyScrapt,OutWorkFlag,S_ScheduledDate,S_ResourceID,S_ScheduledSeqNo,S_ShiftNo,
  534. S_WorkCenterNo,ParkFlag,TimeRequired_Original,QtyRequired_Original,QtyReturntoSchedule,StartProdFlag,CancelledProdFlag,
  535. Efficiency,EnteredDate,SelectedFlag,SourceFlag,Closedby,ClosedDate,VirtualResourceFlag,mat_issueflag,plate_issueflag,
  536. tool_issueflag,scheduleType,operatorId,partNo,orderRef1) values
  537. (#{site},#{orderNo},#{itemNo},#{seqNo},#{qtyRequired},0,0,0,0,#{planStartTime},#{planFinishTime},
  538. #{barcodeID},#{remark},#{crewsize},'N',0,'Y',#{sScheduledDate},#{sResourceID},#{sScheduledSeqNo},#{sShiftNo},
  539. #{sWorkCenterNo},#{parkFlag},#{timeRequiredOriginal},#{qtyRequiredOriginal},null,'N','N',
  540. 0,GetDate(),'N','N',NULL,NULL,NULL,'N','N','N',#{scheduleType},#{operatorId},#{partNo},#{orderRef1}
  541. )
  542. </insert>
  543. <update id="closeSchedule">
  544. update SOScheduledRouting set ClosedFlag='Y' where site=#{site} and seqNo=#{seqNo}
  545. </update>
  546. <select id="getTransData" resultType="com.heai.modules.production.entity.SOOpsTransferData">
  547. select top 1 a.TransNo,a.Site,b.FromWorkCenterNo WorkCenterNo ,b.OrderNo,b.TransQty,a.TransDate,b.PartNo,b.seqNo,dbo.Get_Part_DescSpec(a.Site,b.PartNo) partDesc
  548. ,dbo.Get_Part_UMID(a.Site,b.PartNo) umid
  549. FROM SOOpsTransferHeader a left join SOOpsTransferDetail b on a.site=b.site and a.TransNo=b.TransNo
  550. where a.TransNo=#{transNo} and a.Site=#{site} and ToTypeFlag_DB!='I'
  551. </select>
  552. <select id="searchTaskTransNo" resultType="String">
  553. select top 1 TransNo from SOOpsTransferDetail where OrderNo=#{taskNo} and site=#{site}
  554. </select>
  555. <select id="transFerSearch" resultType="com.heai.modules.production.entity.SOOpsTransferData">
  556. SELECT a.transNo ,a.site,b.seqNo,a.TransDate,b.TransQty ,b.OrderNo ,b.PartNo,c.PartDescription as partDesc
  557. FROM SOOpsTransferHeader a LEFT JOIN SOOpsTransferDetail b on a.TransNo=b.TransNo and a.site=b.Site
  558. LEFT JOIN Part c on b.PartNo=c.PartNo and b.site=c.site
  559. <where>
  560. and a.Status='已录入' and a.ToTypeFlag_DB!='I'
  561. <if test="startDate != null ">
  562. and TransDate >= #{startDate}
  563. </if>
  564. <if test="endDate != null ">
  565. and #{endDate} >= TransDate -1
  566. </if>
  567. <if test="site != null and site != ''">
  568. AND a.site = #{site}
  569. </if>
  570. <if test="orderNo != null and orderNo != ''">
  571. AND orderNo LIKE #{orderNo}
  572. </if>
  573. <if test="seqNo != null and seqNo != ''">
  574. AND seqNo = #{seqNo}
  575. </if>
  576. <if test="partNo != null and partNo != ''">
  577. AND b.PartNo LIKE #{partNo}
  578. </if>
  579. </where>
  580. ORDER BY a.TransDate
  581. </select>
  582. <select id="getPartCardPrintData" resultType="com.heai.modules.production.entity.PartCardPrintData">
  583. select top 1 a.orderNo,a.partNo,c.partDescription+'/'+C.Spec as partDesc,a.QtyRequired,a.S_ScheduledDate,
  584. dbo.Get_OperatorDesc(a.site,a.operatorId) OperatorName ,c.ToExpireDays,b.TechInfo,c.remark,Round(dbo.Get_PartWeightFactorForReport(a.site,a.PartNo,a.OrderNo)*a.QtyRequired,2) as weight
  585. from SOScheduledRouting a left join ShopOrder b on a.site=b.site and a.OrderNo=b.OrderNo
  586. left join part c on a.partNo=c.PartNo and a.site=c.site
  587. where a.site=#{site} and a.seqNo=#{seqNo}
  588. </select>
  589. <select id="checkTool" resultType="com.heai.modules.production.entity.SOToolData">
  590. select ToolID from SOTool where site=#{site} and OrderNo=#{orderNo} and itemNo=#{itemNo}
  591. </select>
  592. <select id="getHunlianTaskNo" resultType="String">
  593. select 'HL'+CONVERT(varchar(100), GETDATE(), 112)+ Right( '00000'+ convert(VARCHAR(10), isnull(max(convert(INT,SUBSTRING(TaskNo, 11,4))),0)+1) ,4) from Hunlian_TaskHeader where TaskNo like 'HL'+CONVERT(varchar(100), GETDATE(), 112)+'%'
  594. </select>
  595. <insert id="saveHunlianTaskDetailData" >
  596. insert into Hunlian_TaskDetail (Site,TaskNo,OrderNo,OrderRef1,OrderRef2,OrderQty,HunlianQty,OrderDate,PartNo,HunlianPartNo)
  597. select top 1 #{site},#{taskNo},#{orderNo},#{orderRef1},SO.OrderNo, SOT.OrderQty,#{hunlianQty},#{orderDate},SOT.partNo,#{hunlianPartNo}
  598. from SOTaskOrderHeader SOT
  599. left join ShopOrder t on t.site=#{site} and t.orderNo=#{orderRef1}
  600. left join ShopOrder SO on SOT.site=SO.Site and t.E_OriginalOrderNo=SO.E_OriginalOrderNo and t.E_OriginalOrderType=SO.E_OriginalOrderType and SO.E_Levels=2
  601. where SOT.site=#{site} and SOT.orderNo=#{orderNo}
  602. </insert>
  603. <select id="checkTask" resultType="com.heai.modules.production.entity.HunlianTaskDetailData">
  604. select OrderNo as orderRef1 ,orderNo_hunlian as orderNo FROM view_KANBAN_SO_Hunlian_Plan
  605. where site=#{site} and (erpStatus='已取消' or FinishedFlag in ('2','3') or dispatched_hunlian='Y' ) and orderNo_hunlian in
  606. (select orderNo from Hunlian_TaskDetail where site=#{site} and TaskNo=#{taskNo} )
  607. </select>
  608. <update id="updateSOTaskDispatchedFlag" >
  609. update SOTaskOrderHeader set dispatched_hunlian =#{flag} where site=#{site} and orderNo in
  610. (select orderNo from Hunlian_TaskDetail where site=#{site} and TaskNo=#{taskNo} )
  611. </update>
  612. <update id="updateTaskReportFlag" >
  613. update Hunlian_TaskHeader set ReportFlag=#{flag} ,ReportQty=#{reportQty},reportReal=#{qtyReal} where site=#{site} and TaskNo=#{taskNo}
  614. </update>
  615. <insert id="saveHunlianTaskHeaderData" >
  616. insert into Hunlian_TaskHeader (Site,TaskNo,TaskQty,PartNo,CreateDate,CreateBy,ReportFlag,ReportQty,DeleteFlag,WareHouseFlag,WareHouseQty,Remark,OrderRef1)
  617. values(#{site},#{taskNo},#{taskQty},#{partNo},GetDate(),#{createBy},'N',0,'N','N',0,#{remark},#{orderRef1})
  618. </insert>
  619. <select id="getPartNoOnHand" resultType="com.heai.modules.production.entity.InventoryStockSearchData">
  620. select site,partNo, Round(sum(QtyOnHand),2) QtyOnHand from InventoryStock where site=#{site} and partNo=#{partNo} group by site,partNo
  621. </select>
  622. <select id="getHunlianTaskData" resultType="com.heai.modules.production.entity.HunlianData">
  623. select a.Site,a.TaskNo,a.TaskQty,a.PartNo,a.CreateDate,a.CreateBy,a.ReportFlag,a.ReportQty,dbo.Get_Part_DescSpec(a.Site,a.PartNo) as partDesc
  624. ,b.toExpireDays,a.WareHouseFlag,a.remark,a.orderRef1
  625. from Hunlian_TaskHeader a
  626. left join part b on a.site=b.site and a.PartNo=b.partNo
  627. <where>
  628. and a.deleteFlag='N'
  629. <if test="startDate != null ">
  630. and a.CreateDate >= #{startDate}
  631. </if>
  632. <if test="endDate != null ">
  633. and #{endDate} >= a.CreateDate -1
  634. </if>
  635. <if test="reportFlag != null and reportFlag != ''">
  636. AND a.reportFlag = #{reportFlag}
  637. </if>
  638. <if test="partNo != null and partNo != ''">
  639. AND a.partNo like #{partNo}
  640. </if>
  641. <if test="taskNo != null and taskNo != ''">
  642. AND a.taskNo LIKE #{taskNo}
  643. </if>
  644. </where>
  645. ORDER BY a.CreateDate
  646. </select>
  647. <select id="getHunlianTaskDetailData" resultType="com.heai.modules.production.entity.HunlianTaskDetailData">
  648. select a.Site,a.TaskNo,a.OrderNo,a.OrderRef1,a.OrderRef2,a.OrderQty,a.HunlianQty,a.OrderDate,a.PartNo,a.HunlianPartNo,
  649. dbo.Get_Part_DescSpec(a.Site,a.HunlianPartNo) as partDesc
  650. from Hunlian_TaskDetail a
  651. where site=#{site} and TaskNo=#{taskNo}
  652. </select>
  653. <select id="getHunlianTaskDetailDataSum" resultType="com.heai.modules.production.entity.HunlianTaskDetailData">
  654. select a.Site,a.TaskNo,a.OrderRef2,SUM(a.HunlianQty) HunlianQty,a.HunlianPartNo
  655. from Hunlian_TaskDetail a
  656. where site=#{site} and TaskNo=#{taskNo}
  657. GROUP BY a.Site,a.TaskNo,a.OrderRef2,a.HunlianPartNo
  658. </select>
  659. <select id="checkTaskHeader" resultType="com.heai.modules.production.entity.HunlianData">
  660. select Site,TaskNo,TaskQty,PartNo,CreateDate,CreateBy,ReportFlag,ReportQty,DeleteFlag,DeleteBy,DeleteDate,WareHouseFlag,orderRef1 from Hunlian_TaskHeader
  661. where site=#{site} and DeleteFlag='N' and TaskNo=#{taskNo}
  662. </select>
  663. <select id="checkTaskOrder" resultType="com.heai.modules.production.entity.HunlianData">
  664. select orderNo from shopOrder where status in ('已取消','已关闭') and site=#{site} and orderNo in (select orderRef1 from Hunlian_TaskDetail where site=#{site}
  665. and taskNo=#{taskNo} )
  666. </select>
  667. <update id="deleteTask">
  668. update Hunlian_TaskHeader set DeleteFlag='Y',DeleteBy=#{userId},DeleteDate=GetDate() where site=#{site} and TaskNo=#{taskNo}
  669. </update>
  670. <update id="updateSOTaskReport" parameterType="com.heai.modules.production.entity.DailyReportInData">
  671. update SOTaskOrderHeader SET Qtyfinished=Round(#{reportQty}*#{orderQty}/#{taskQty},1),ReportTime=GetDate(),FinishFlag='Y',ReportBy=#{userId} ,InputQty=Round(#{reportQty}*#{hunlianQty}/#{taskQty},1) where OrderNo=#{orderNo} and site =#{site}
  672. </update>
  673. <update id="cancelReportSOTask" parameterType="com.heai.modules.production.entity.HunlianData">
  674. update SOTaskOrderHeader SET Qtyfinished=0,ReportTime=null,FinishFlag='N',ReportBy=null ,InputQty=0 where site =#{site} and orderNo in (select orderNo from Hunlian_TaskDetail where site =#{site} and taskNo=#{taskNo})
  675. </update>
  676. <insert id="saveSOOpsTransferHeader">
  677. INSERT INTO SOOpsTransferHeader (TransNo,Site,FromProLineNo,ToProLineNo,ToWarehouseID,FromEnteredby,FromEnteredDate,TransDate,ToReceiver,FromReceiver,
  678. FromRemark,ToRemark,ConfirmedFlag,ToConfirmedBy,ToEnteredby,LatestUpdatedBy,LatestUpdatedDate,RecordVersion,
  679. Status,ToTypeFlag_DB,ToTypeFlag,ConfirmedTransNo,need_inspect_flag,NeedReceiveFlag) VALUES
  680. (#{transNo},#{site},'*','*','*',#{userId},GETDATE(),GETDATE(),'',#{userId},
  681. '','','N','N','',#{userId},GETDATE(),'0',
  682. '已录入','W','混炼胶入库','','Y','N')
  683. </insert>
  684. <insert id="saveSOOpsTransferDetail">
  685. INSERT INTO SOOpsTransferDetail (TransNo,Site,ItemNo,FromOpsID,FromWorkCenterNo,ToWorkCenterNo,ToOpsID,OrderNo,PartNo,TransQty,ConfirmQty,TaskNo,InsStatus,
  686. ToConfirmQty) VALUES
  687. ( #{transNo},#{site},1,1,'*','',0,#{taskNo},#{partNo},#{reportQty},0,#{taskNo},'合格',0)
  688. </insert>
  689. <insert id="saveSOOpsTransferHeaderForShiYanShi">
  690. INSERT INTO SOOpsTransferHeader (TransNo,Site,FromProLineNo,ToProLineNo,ToWarehouseID,FromEnteredby,FromEnteredDate,TransDate,ToReceiver,FromReceiver,
  691. FromRemark,ToRemark,ConfirmedFlag,ToConfirmedBy,ToEnteredby,LatestUpdatedBy,LatestUpdatedDate,RecordVersion,
  692. Status,ToTypeFlag_DB,ToTypeFlag,ConfirmedTransNo,need_inspect_flag,NeedReceiveFlag) VALUES
  693. (#{transNo},#{site},'*','*','*',#{operatorId},GETDATE(),GETDATE(),'',#{operatorId},
  694. '','','N','N','',#{operatorId},GETDATE(),'0',
  695. '已录入','I',#{toTypeFlag},'','Y','N')
  696. </insert>
  697. <insert id="saveSOOpsTransferDetailForShiYanShi">
  698. INSERT INTO SOOpsTransferDetail (TransNo,Site,ItemNo,FromOpsID,FromWorkCenterNo,ToWorkCenterNo,ToOpsID,OrderNo,PartNo,TransQty,ConfirmQty,TaskNo,InsStatus,
  699. ToConfirmQty,seqNo) VALUES
  700. ( #{transNo},#{site},1,1,#{sWorkCenterNo},'',0,#{orderNo},#{partNo},#{qtyRequired},0,#{orderNo},'待检验',0,#{seqNo})
  701. </insert>
  702. <select id="getTransNo" resultType="String">
  703. select 'OT'+CONVERT(varchar(100), GETDATE(), 112)+ Right( '00000'+ convert(VARCHAR(10), isnull(max(convert(INT,SUBSTRING(TransNo, 11,4))),0)+1) ,4)
  704. from SOOpsTransferHeader where TransNo like 'OT'+CONVERT(varchar(100), GETDATE(), 112)+'%'
  705. </select>
  706. <select id="checkLocationId" resultType="com.heai.modules.production.entity.LocationData">
  707. select LocationID,Site,LocationName,WareHouseID,Keeper,Active
  708. from Location where site=#{site} and LocationID=#{locationId}
  709. </select>
  710. <delete id="deleteSOOpsTransferHeader">
  711. update SOOpsTransferHeader set Status='已取消' where site=#{site} and transNo=#{transNo}
  712. </delete>
  713. <delete id="deleteSOOpsTransferDetail">
  714. delete from SOOpsTransferDetail where site=#{site} and transNo=#{transNo}
  715. </delete>
  716. <select id="getSfdcList" resultType="com.heai.modules.production.entity.SfdcCancel">
  717. select a.site,a.OrderNo,a.ItemNo ,a.SeqNo,a.WorkCenterNo,a.ReportDate,a.OperatorID,a.ReportQty,a.ApproveQty,a.ReportedManfTime,a.StatisticDate,
  718. a.AssJobSeqNo,a.Scheduled_ResourceId ResourceID,b.S_ShiftNo ShiftNo,b.partNo,dbo.Get_ItemDesc(a.site,a.OrderNo,a.ItemNo) operation_desc,c.OperatorName,b.S_ShiftNo ShiftDesc,e.ResourceDesc,Reverseflag
  719. from sfdc a LEFT JOIN SOScheduledRouting b on a.Site=b.Site and a.AssJobSeqNo=b.SeqNo
  720. left join Operator c on a.site=c.site and a.OperatorID=c.OperatorID
  721. left join WorkCenterResource e on a.Site=e.Site and a.Scheduled_ResourceId =e.ResourceID and a.WorkCenterNo=e.WorkCenterNo
  722. <where>
  723. and a.AssJobSeqNo is not null
  724. <if test="orderNo != null and orderNo != ''">
  725. and a.OrderNo like #{orderNo}
  726. </if>
  727. <if test="workCenterNo != null and workCenterNo != ''">
  728. and a.WorkCenterNo like #{workCenterNo}
  729. </if>
  730. <if test="partNo != null and partNo != ''">
  731. and b.partNo like #{partNo}
  732. </if>
  733. <if test="itemNo != null and itemNo != ''">
  734. and a.ItemNo = #{itemNo}
  735. </if>
  736. <if test="operatorName != null and operatorName != ''">
  737. and c.OperatorName like #{operatorName}
  738. </if>
  739. <if test="resourceId != null and resourceId != ''">
  740. and a.Scheduled_ResourceId = #{resourceId}
  741. </if>
  742. <if test="shiftNo != null and shiftNo != ''">
  743. and b.S_ShiftNo = #{shiftNo}
  744. </if>
  745. <if test="startDate != null ">
  746. and ReportDate >= #{startDate}
  747. </if>
  748. <if test="endDate != null ">
  749. and #{endDate} >= ReportDate
  750. </if>
  751. <if test="seqNo != null and seqNo != '' ">
  752. and a.AssJobSeqNo = #{seqNo}
  753. </if>
  754. </where>
  755. order by a.ReportDate desc
  756. </select>
  757. <update id="changeReceiveFlag">
  758. update SOOpsTransferHeader set NeedReceiveFlag=#{flag} from SOOpsTransferDetail b where SOOpsTransferHeader.site=b.site
  759. and SOOpsTransferHeader.transNo=b.transNo and SOOpsTransferHeader.status='已录入' and SOOpsTransferHeader.ToTypeFlag_DB='W' and
  760. b.seqNo=#{seqNo} and SOOpsTransferHeader.site=#{site}
  761. </update>
  762. </mapper>