ClssSql.py 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. class ClassSqls:
  2. # 共用的
  3. # 存储过程
  4. ccc = """alter FUNCTION [dbo].[f_splitSTR](
  5. @s varchar(8000), --待分拆的字符串
  6. @split varchar(10) --数据分隔符
  7. )RETURNS @re TABLE(col varchar(100))
  8. AS
  9. BEGIN
  10. DECLARE @splitlen int
  11. SET @splitlen = LEN(@split + 'a') - 2
  12. WHILE CHARINDEX(@split,@s) > 0
  13. BEGIN
  14. INSERT @re VALUES(LEFT(@s,CHARINDEX(@split,@s) - 1))
  15. SET @s = STUFF(@s,1,CHARINDEX(@split,@s)+@splitlen,'')
  16. END
  17. INSERT @re VALUES(@s)
  18. UPDATE A SET a.col=b.NAME FROM @re A,SALM B WITH (NOLOCK) WHERE A.COL=B.SAL_NO
  19. RETURN
  20. END"""
  21. aaaa="""select left(Convert(varchar(100), no_dd, 23), 11) as no_dd,create_time,update_time,bg_no,bg_id,zc_no,(
  22. select
  23. (
  24. stuff(
  25. (select ',' + col from f_splitSTR(rtrim((replace(replace(replace(replace(sal_no,'[',''),']',''),'''',''),' ',''))),',') for xml path('')),1,1,''))
  26. ) as sal_no,create_user,update_user,mo_no from django_mf_bg"""
  27. # 1、这里是插入通知单自定义表的单号
  28. CommonSql_z = """INSERT INTO MF_TZ_Z(TZ_NO) SELECT A.TZ_NO FROM MF_TZ A WITH (NOLOCK) LEFT JOIN MF_TZ_Z B WITH(NOLOCK) ON A.TZ_NO=B.TZ_NO WHERE ISNULL(B.TZ_NO,'')='' """
  29. # 2、生产单号sql
  30. CommonSqlNo = """select max(right(bg_no,11)) as bg_no from django_mf_bg where left(Convert(varchar(100), no_dd, 23), 11) = CONVERT(varchar(10),GETDATE(),120) and bg_id='{0}'"""
  31. # 3、查询(Django_tf_bg)表身需要删除的单据
  32. CommonTfSql = """select a.zt_no,a.bg_id,a.qty,a.zl,b.qty_pg_lx,b.qty_sh_lx,b.spc_no,a.mo_no,a.zd_zc from Django_tf_bg a,(select a.tz_no,isnull(b.spc_no,0) as spc_no,c.qty_pg_lx,c.qty_sh_lx from
  33. mf_tz a,dept b,mf_tz_z c where a.tz_no=c.tz_no and a.dep=b.dep)b where a.zt_no=b.tz_no and a.bg_no_id='{0}'"""
  34. # 4、单据查询
  35. # 查询表头
  36. CommonMf_sql = """select left(Convert(varchar(100), no_dd, 23), 11) as no_dd,create_time,update_time,bg_no,bg_id,zc_no,sal_no,create_user,update_user,mo_no,cast(isbad as int) as isbad,isnull(zd_zc,'') as zd_zc from django_mf_bg where bg_no='{0}'"""
  37. CommonTf_sql = """select left(Convert(varchar(100), a.no_dd, 23), 11) as no_dd,a.itm,a.bg_id,a.mo_no,a.zt_no,a.prd_no,a.prd_name,a.cc,a.zy,a.qty,a.zl,a.ms,a.rem,a.dd,a.prd_rem,a.bg_no_id,
  38. a.sal_no,a.zc_no_up,a.zc_no_end as zc_no_dn,b.spc_no,isnull(a.zd_zc,'') as zd_zc from django_tf_bg a,(select a.tz_no,isnull(b.spc_no,0) as spc_no from mf_tz a,dept b
  39. where a.dep=b.dep)b where a.zt_no=b.tz_no and a.bg_no_id='{0}' order by a.itm asc"""
  40. # 5、查看用户信息
  41. CommonUsers = """select a.username as value,cast(a.username as varchar(20))+'--'+b.name as label from users a left join SunSystem..PSWD b on a.username=b.usr and b.compno='01'"""
  42. # 5、弹窗条件查询的sql
  43. # 查询通知单
  44. CommonFilter = """select left(Convert(varchar(100), no_dd, 23), 11) as no_dd,create_time,update_time,bg_no,bg_id,zc_no,(
  45. select
  46. (
  47. stuff(
  48. (select ',' + col from f_splitSTR(rtrim((replace(replace(replace(replace(sal_no,'[',''),']',''),'''',''),' ',''))),',') for xml path('')),1,1,''))
  49. ) as sal_no,create_user,update_user,mo_no from django_mf_bg {0}"""
  50. # 各类单据过滤查询
  51. # TzInfoJs = """select 0 as zl, a.zc_no,a.mo_no,a.tz_no as zt_no,a.mrp_no as prd_no,c.name as prd_name,isnull(a.Qty,0)-isnull(e.qty_js_lx,0)as qty,
  52. # isnull(a.Qty,0)-isnull(e.qty_js_lx,0) as yscl,b.sc_lx as cc,b.zy_lx as zy,a.rem as ms,a.rrem as rem,d.dd,c.rem as prd_rem,isnull(a.qty,0) as totalqty,
  53. # zc_no_up = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_up),
  54. # zc_no_dn = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_dn),
  55. # isnull(f.spc_no,0) as spc_no
  56. # from MF_TZ a
  57. # left join (select aa.sc_lx,aa.zy_lx,aa.os_no,bb.mo_no from
  58. # tf_pos_z aa,mf_mo bb,tf_pos cc where cc.os_id='SO' AND AA.OS_ID=CC.OS_ID and aa.itm=cc.itm and aa.os_no=cc.os_no and cc.est_itm=bb.est_itm and aa.os_no=bb.so_no)b on a.mo_no=b.mo_no
  59. # left join prdt c on a.mrp_no=c.prd_no
  60. # left join prdt_z d on c.prd_no=d.prd_no
  61. # left join mF_TZ_z e on a.tz_no=e.tz_no
  62. # left join dept f on f.dep = a.dep
  63. # where isnull(a.close_id,'')<>'T' and isnull(a.Qty,0)>isnull(e.qty_js_lx,0) and a.zc_no='{0}' and a.mo_no in('MO06230001','MO06220004')"""
  64. TzInfoJs = """select 0 as zl, a.zc_no,a.mo_no,a.tz_no as zt_no,a.mrp_no as prd_no,c.name as prd_name,case when isnull(a.zc_no_up,'')<>'' then isnull(e.qty_djs_lx ,0) else isnull(a.qty,0) end-isnull(e.qty_js_lx,0)as qty,
  65. case when isnull(a.zc_no_up,'')<>'' then isnull(e.qty_djs_lx ,0) else isnull(a.qty,0) end-isnull(e.qty_js_lx,0) as yscl,b.sc_lx as cc,b.zy_lx as zy,a.rem as ms,a.rrem as rem,d.dd,c.rem as prd_rem,
  66. case when isnull(a.zc_no_up,'')<>'' then isnull(e.qty_djs_lx ,0) else isnull(a.qty,0) end as totalqty,
  67. zc_no_up = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_up),
  68. zc_no_dn = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_dn),
  69. isnull(f.spc_no,0) as spc_no
  70. from MF_TZ a
  71. left join (select aa.sc_lx,aa.zy_lx,aa.os_no,bb.mo_no from
  72. tf_pos_z aa,mf_mo bb,tf_pos cc where cc.os_id='SO' AND AA.OS_ID=CC.OS_ID and aa.itm=cc.itm and aa.os_no=cc.os_no and cc.est_itm=bb.est_itm and aa.os_no=bb.so_no)b on a.mo_no=b.mo_no
  73. left join prdt c on a.mrp_no=c.prd_no
  74. left join prdt_z d on c.prd_no=d.prd_no
  75. left join mF_TZ_z e on a.tz_no=e.tz_no
  76. left join dept f on f.dep = a.dep
  77. where isnull(a.close_id,'')<>'T' and case when isnull(a.zc_no_up,'')<>'' then isnull(e.qty_djs_lx ,0) else isnull(a.Qty,0) end > isnull(e.qty_js_lx,0) and a.zc_no='{0}'"""
  78. TzInfoPg = """select 0 as zl, a.zc_no,a.mo_no,a.tz_no as zt_no,a.mrp_no as prd_no,c.name as prd_name,isnull(e.qty_js_lx,0)-isnull(e.qty_pg_lx,0)
  79. as qty,isnull(e.qty_js_lx,0)-isnull(e.qty_pg_lx,0) as yscl,b.sc_lx as cc,b.zy_lx as zy,a.rem as ms,a.rrem as rem,d.dd,c.rem as prd_rem,isnull(e.qty_js_lx,0)as totalqty,
  80. zc_no_up = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_up),
  81. zc_no_dn = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_dn)
  82. from MF_TZ a
  83. left join (select aa.sc_lx,aa.zy_lx,aa.os_no,bb.mo_no from
  84. tf_pos_z aa,mf_mo bb,tf_pos cc where cc.os_id='SO' AND AA.OS_ID=CC.OS_ID and aa.itm=cc.itm and aa.os_no=cc.os_no and cc.est_itm=bb.est_itm and aa.os_no=bb.so_no)b on a.mo_no=b.mo_no
  85. left join prdt c on a.mrp_no=c.prd_no
  86. left join prdt_z d on c.prd_no=d.prd_no
  87. left join mF_TZ_z e on a.tz_no=e.tz_no
  88. where isnull(a.close_id,'')<>'T' and isnull(e.qty_js_lx,0)>isnull(e.qty_pg_lx,0) and a.zc_no='{0}' and a.mo_no='{1}'"""
  89. TzInfoSh = """select 0 as zl, a.zc_no,a.mo_no,a.tz_no as zt_no,a.mrp_no as prd_no,c.name as prd_name,isnull(e.qty_pg_lx,0)-isnull(e.qty_sh_lx,0)
  90. as qty,isnull(e.qty_pg_lx,0)-isnull(e.qty_sh_lx,0) as yscl,b.sc_lx as cc,b.zy_lx as zy,a.rem as ms,a.rrem as rem,d.dd,c.rem as prd_rem,isnull(e.qty_pg_lx,0) as totalqty,
  91. zc_no_up = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_up),
  92. zc_no_dn = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_dn) ,
  93. sal_no=(select top 1 c1.sal_no+'-'+c1.name as sal_no from django_mf_bg a1,django_tf_bg b1,salm c1 where
  94. REPLACE(REPLACE(a1.sal_no,''']',''),'[''','')=c1.sal_no and a1.bg_no=b1.bg_no_id and a1.bg_id='PG' and b1.zt_no=a.tz_no)
  95. from MF_TZ a
  96. left join (select aa.sc_lx,aa.zy_lx,aa.os_no,bb.mo_no from
  97. tf_pos_z aa,mf_mo bb,tf_pos cc where cc.os_id='SO' AND AA.OS_ID=CC.OS_ID and aa.itm=cc.itm and aa.os_no=cc.os_no and cc.est_itm=bb.est_itm and aa.os_no=bb.so_no)b on a.mo_no=b.mo_no
  98. left join prdt c on a.mrp_no=c.prd_no
  99. left join prdt_z d on c.prd_no=d.prd_no
  100. left join mF_TZ_z e on a.tz_no=e.tz_no
  101. where isnull(a.close_id,'')<>'T' and isnull(e.qty_pg_lx,0)>isnull(e.qty_sh_lx,0) and a.zc_no='{0}' and a.mo_no='{1}'"""
  102. # 按单号过滤
  103. TzInfoZy = """select 0 as zl, a.zc_no,a.mo_no,a.tz_no as zt_no,a.mrp_no as prd_no,c.name as prd_name,isnull(e.qty_sh_lx,0)-isnull(e.qty_zy_lx,0)-isnull(QTY_YCGD_LX,0)
  104. as qty,isnull(e.qty_sh_lx,0)-isnull(e.qty_zy_lx,0)-isnull(QTY_YCGD_LX,0) as yscl, b.sc_lx as cc,b.zy_lx as zy,a.rem as ms,a.rrem as rem,d.dd,c.rem as prd_rem,isnull(e.qty_sh_lx,0) as totalqty,
  105. zc_no_up = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_up),
  106. zc_no_dn = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_dn)
  107. from MF_TZ a
  108. left join (select aa.sc_lx,aa.zy_lx,aa.os_no,bb.mo_no from
  109. tf_pos_z aa,mf_mo bb,tf_pos cc where cc.os_id='SO' AND AA.OS_ID=CC.OS_ID and aa.itm=cc.itm and aa.os_no=cc.os_no and cc.est_itm=bb.est_itm and aa.os_no=bb.so_no)b on a.mo_no=b.mo_no
  110. left join prdt c on a.mrp_no=c.prd_no
  111. left join prdt_z d on c.prd_no=d.prd_no
  112. left join mF_TZ_z e on a.tz_no=e.tz_no
  113. where isnull(a.close_id,'')<>'T' and isnull(e.qty_sh_lx,0)>isnull(e.qty_zy_lx,0)+isnull(QTY_YCGD_LX,0) and a.zc_no='{0}' and a.mo_no='{1}' and a.zc_no_dn='{2}'"""
  114. # 过滤全部
  115. TzInfoZy1 = """select 0 as zl, a.zc_no,a.mo_no,a.tz_no as zt_no,a.mrp_no as prd_no,c.name as prd_name,isnull(e.qty_sh_lx,0)-isnull(e.qty_zy_lx,0)-isnull(QTY_YCGD_LX,0)
  116. as qty,isnull(e.qty_sh_lx,0)-isnull(e.qty_zy_lx,0)-isnull(QTY_YCGD_LX,0) as yscl, b.sc_lx as cc,b.zy_lx as zy,a.rem as ms,a.rrem as rem,d.dd,c.rem as prd_rem,isnull(e.qty_sh_lx,0) as totalqty,
  117. zc_no_up = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_up),
  118. zc_no_dn = (select isnull(zc_no+'-'+name,'') from zc_no where zc_no=a.zc_no_dn)
  119. from MF_TZ a
  120. left join (select aa.sc_lx,aa.zy_lx,aa.os_no,bb.mo_no from
  121. tf_pos_z aa,mf_mo bb,tf_pos cc where cc.os_id='SO' AND AA.OS_ID=CC.OS_ID and aa.itm=cc.itm and aa.os_no=cc.os_no and cc.est_itm=bb.est_itm and aa.os_no=bb.so_no)b on a.mo_no=b.mo_no
  122. left join prdt c on a.mrp_no=c.prd_no
  123. left join prdt_z d on c.prd_no=d.prd_no
  124. left join mF_TZ_z e on a.tz_no=e.tz_no
  125. where isnull(a.close_id,'')<>'T' and isnull(e.qty_sh_lx,0)>isnull(e.qty_zy_lx,0)+isnull(QTY_YCGD_LX,0) and a.zc_no='{0}' and a.zc_no_dn='{1}'"""
  126. # 批量导入用户
  127. InsetUser = """insert into users(last_login,is_superuser,username,first_name,last_name,email,is_staff,is_active,date_joined,password)
  128. select '' as last_login,0 as is_superuser, usr as username,'' as first_name,'' as last_name,'123456@qq.com' as email,
  129. 1 as is_staff,1 as is_active,'' as date_joined,'pbkdf2_sha256$150000$cr8SzfavxM7f$2hVNA/mT/iVW4aC/ibGUjjMPcoqGl0JdCJnYqoqmt68=' as password
  130. from SunSystem..PSWD where usr not in(select username from users)and compno='01'"""
  131. # 接收单
  132. # 更新通知单栏位,如果spc_no==0时
  133. BgUpSql = """update a set a.qty_js_lx=b.qty,a.qty1_js_lx=b.zl from MF_TZ_Z a,(select sum(isnull(qty,0)) as qty,sum(isnull(cast(zl as float),0)) as zl,
  134. zt_no from Django_tf_bg where zt_no='{0}' and bg_id='{1}' group by zt_no)b WHERE a.tz_no=b.zt_no"""
  135. # 更新通知单栏位,如果spc_no==1时
  136. BgUpSql1 = """update a set a.qty_js_lx=b.qty,a.qty1_js_lx=b.zl,a.qty_pg_lx=b.qty,a.qty_sh_lx=b.qty from MF_TZ_Z a,(select sum(isnull(qty,0)) as qty,sum(isnull(cast(zl as float),0)) as zl,
  137. zt_no from Django_tf_bg where zt_no='{0}' and bg_id='{1}' group by zt_no)b WHERE a.tz_no=b.zt_no"""
  138. # 删除的时候更新,当spc_no=0时
  139. BgUpdel = """update MF_TZ_Z set qty_js_lx=isnull(qty_js_lx,0)-{0},qty1_js_lx=isnull(qty1_js_lx,0)-{1} where tz_no='{2}'"""
  140. # 删除的时候更新,当spc_no=1时
  141. BgUpdel1 = """update MF_TZ_Z set qty_js_lx=isnull(qty_js_lx,0)-{0},qty1_js_lx=isnull(qty1_js_lx,0)-{1},qty_pg_lx=isnull(qty_pg_lx,0)-{3},qty_sh_lx=isnull(qty_sh_lx,0)-{4} where tz_no='{2}'"""
  142. # 查询单据的时候计算应生产量
  143. BgYscl = """SELECT ISNULL(A.QTY,0)-ISNULL(B.QTY_JS_LX,0) AS qty,a.tz_no,a.QTY as totalqty,cast(ISNULL(B.QTY_PG_LX,0) as float) as pgqty FROM MF_TZ A,MF_TZ_Z B WHERE A.TZ_NO=B.TZ_NO AND A.TZ_NO='{0}'"""
  144. # 派工单
  145. # 删除的时候更新
  146. PgUpdel = """update MF_TZ_Z set qty_pg_lx=isnull(qty_pg_lx,0)-{0},qty1_pg_lx=isnull(qty1_pg_lx,0)-{1} where tz_no='{2}'"""
  147. PgUpSql = """update a set a.qty_pg_lx=b.qty,a.qty1_pg_lx=b.zl from MF_TZ_Z a,(select sum(isnull(qty,0)) as qty,sum(isnull(cast(zl as float),0)) as zl,
  148. zt_no from Django_tf_bg where zt_no='{0}' and bg_id='{1}' group by zt_no)b WHERE a.tz_no=b.zt_no"""
  149. PgYscl = """select isnull(qty_js_lx,0)-isnull(qty_pg_lx,0) as qty,tz_no,qty_js_lx as totalqty from MF_TZ_Z where tz_no='{0}'"""
  150. # 收货单
  151. # 删除的时候更新
  152. ShUpdel = """update MF_TZ_Z set qty_sh_lx=isnull(qty_sh_lx,0)-{0},qty1_sh_lx=isnull(qty1_sh_lx,0)-{1} where tz_no='{2}'"""
  153. ShUpSql = """update a set a.qty_sh_lx=b.qty,a.qty1_sh_lx=b.zl from MF_TZ_Z a,(select sum(isnull(qty,0)) as qty,sum(isnull(cast(zl as float),0)) as zl,
  154. zt_no from Django_tf_bg where zt_no='{0}' and bg_id='{1}' group by zt_no)b WHERE a.tz_no=b.zt_no"""
  155. ShYscl = """select isnull(qty_pg_lx,0)-isnull(qty_sh_lx,0) as qty,tz_no,qty_pg_lx as totalqty from MF_TZ_Z where tz_no='{0}'"""
  156. # 转移单
  157. # 删除的时候更新
  158. # 正常单据
  159. ZyUpdel = """update MF_TZ_Z set qty_zy_lx=isnull(qty_zy_lx,0)-{0},qty1_zy_lx=isnull(qty1_zy_lx,0)-{1} where tz_no='{2}'"""
  160. # 异常单据
  161. ZyUpdel1 = """update MF_TZ_Z set QTY_YCGD_LX=isnull(QTY_YCGD_LX,0)-{0},QTY1_YCGD_LX=isnull(QTY1_YCGD_LX,0)-{1} where tz_no='{2}'"""
  162. # 正常单据更新对应的数量
  163. ZyUpSql = """update a set a.qty_zy_lx=b.qty,a.qty1_zy_lx=b.zl from MF_TZ_Z a,(select sum(isnull(qty,0)) as qty,sum(isnull(cast(zl as float),0)) as zl,
  164. zt_no from Django_tf_bg where zt_no='{0}' and bg_id='{1}' group by zt_no)b WHERE a.tz_no=b.zt_no"""
  165. # 更新下制程的数量栏位
  166. ZyUpSql_dai = """update a set a.QTY_DJS_LX=b.qty,a.QTY1_DJS_LX=b.zl from MF_TZ_Z a,(select sum(isnull(qty,0)) as qty,sum(isnull(cast(zl as float),0)) as zl,
  167. MO_NO from Django_tf_bg where mo_no='{0}' and bg_id='{1}' group by MO_NO)b,MF_TZ C WHERE A.TZ_NO=C.TZ_NO AND C.MO_NO=B.MO_NO and C.ZC_NO='{2}'"""
  168. # 异常单据更新到异常栏位上
  169. ZyUpSql1 = """update a set a.QTY_YCGD_LX=b.qty,a.QTY1_YCGD_LX=b.zl from MF_TZ_Z a,(select sum(isnull(qty,0)) as qty,sum(isnull(cast(zl as float),0)) as zl,
  170. zt_no from Django_tf_bg where zt_no='{0}' and bg_id='{1}' group by zt_no)b WHERE a.tz_no=b.zt_no"""
  171. ZyYscl = """select isnull(qty_sh_lx,0)-isnull(qty_zy_lx,0)-isnull(qty_ycgd_lx,0) as qty,tz_no,qty_sh_lx as totalqty from MF_TZ_Z where tz_no='{0}'"""
  172. # 通知单以生产量、自定义栏位
  173. ZySelfz = """select isnull(a.qty_fin,0) as qty_fin,isnull(a.qty,0) as qty from MF_TZ a,MF_TZ_z b where a.tz_no=b.tz_no and a.tz_no='{0}'"""
  174. ZyUpFin = """update a set a.QTY_FIN=isnull(b.qty_zy_lx,0)+isnull(b.QTY_YCGD_LX,0) from MF_TZ a,MF_TZ_z b where a.tz_no=b.tz_no and a.tz_no='{0}'"""
  175. ZyUpClose = """update mf_tz set close_id='T' where tz_no='{0}'"""
  176. ZyUpNoClose = """update mf_tz set close_id='F' where tz_no='{0}'"""
  177. # 更新掉旧的带接收数量
  178. update_old_dai_sql = """update a set a.QTY_DJS_LX=a.QTY_DJS_LX-{0},a.QTY1_DJS_LX=a.QTY1_DJS_LX-{1} from mf_tz_z A,mf_tz b where a.tz_no=b.tz_no and b.mo_no='{2}' and b.zc_no='{3}' """