Query_MakeInf.cs 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. using System;
  2. using System.Data;
  3. using System.Windows.Forms;
  4. using UAS_MES_NEW.DataOperate;
  5. using UAS_MES_NEW.Entity;
  6. using UAS_MES_NEW.PublicMethod;
  7. namespace UAS_MES_NEW.Query
  8. {
  9. public partial class Query_MakeInf : Form
  10. {
  11. AutoSizeFormClass asc = new AutoSizeFormClass();
  12. DataHelper dh;
  13. public Query_MakeInf()
  14. {
  15. InitializeComponent();
  16. }
  17. private void Query_MakeInf_Load(object sender, EventArgs e)
  18. {
  19. asc.controllInitializeSize(this);
  20. dh = SystemInf.dh;
  21. }
  22. private void Query_MakeInf_SizeChanged(object sender, EventArgs e)
  23. {
  24. asc.controlAutoSize(this);
  25. }
  26. private void Search_Click(object sender, EventArgs e)
  27. {
  28. LogStringBuilder sql = new LogStringBuilder();
  29. sql.Clear();
  30. sql.Append("select ma_prodcode,ma_qty,ma_craftcode,ma_wccode,ma_salecode,ma_custname,ma_unlimitageqty");
  31. sql.Append(",ma_softversion,ma_bomversion from make where ma_code='" + MakeCode.Text + "'");
  32. DataTable dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  33. CleanForm(this);
  34. if (dt.Rows.Count > 0)
  35. {
  36. BaseUtil.SetFormValue(this.Controls, dt);
  37. string ma_prodcode = dt.Rows[0]["ma_prodcode"].ToString();
  38. string ma_craftcode = dt.Rows[0]["ma_craftcode"].ToString();
  39. string ma_bomversion = dt.Rows[0]["ma_bomversion"].ToString();
  40. string ma_salecode = dt.Rows[0]["ma_salecode"].ToString();
  41. sql.Clear();
  42. sql.Append("select pr_code,pr_outboxinnerqty,case pr_sendchecktype when 'SaleCode' then '按合同送检' when 'LineCode' then '按线别送检' end pr_sendchecktype,pr_detail,pr_agingtime");
  43. sql.Append(",( CASE WHEN pr_colorboxminw LIKE '.%' THEN '0'||pr_colorboxminw ELSE to_char(pr_colorboxminw) END ||'-'|| CASE WHEN pr_colorboxmaxw LIKE '.%' THEN '0'||pr_colorboxmaxw ELSE to_char(pr_colorboxmaxw) END ||' '||pr_colorboxunit)pr_colorboxweight,");
  44. sql.Append("(CASE WHEN pr_cartonminw LIKE '.%' THEN '0'||pr_cartonminw ELSE to_char(pr_cartonminw) END ||'-'|| CASE WHEN pr_cartonmaxw LIKE '.%' THEN '0'||pr_cartonmaxw ELSE to_char(pr_cartonmaxw) END ||' '||pr_cartonunit)pr_cartonweight from product where pr_code='" + ma_prodcode + "'");
  45. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  46. if (dt.Rows.Count > 0)
  47. {
  48. BaseUtil.SetFormValue(this.Controls, dt);
  49. }
  50. sn_relation.Text = dh.getFieldDataByCondition("productsnrelation", "wm_concat(psr_type)", "psr_prodcode='" + ma_prodcode + "'").ToString();
  51. sql.Clear();
  52. sql.Append("select * from craftdetail left join craft on cd_crid=cr_id where cr_code='" + ma_craftcode + "' and cr_prodcode='" + ma_prodcode + "' order by cd_detno");
  53. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  54. if (dt.Rows.Count > 0)
  55. {
  56. BaseUtil.FillDgvWithDataTable(Carft, dt);
  57. }
  58. sql.Clear();
  59. sql.Append("select (msr_startno||'-'||msr_endno) before_snrange,msr_qty beforesn_qty from makesnrule where msr_makecode='" + MakeCode.Text + "' and msr_type='before'");
  60. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  61. string rangebefore = "0";
  62. if (dt.Rows.Count > 0)
  63. {
  64. rangebefore = dt.Rows[0]["beforesn_qty"].ToString();
  65. BaseUtil.SetFormValue(this.Controls, dt);
  66. }
  67. sql.Clear();
  68. sql.Append("select (msr_startno||'-'||msr_endno) aftersn_range,msr_qty aftersn_qty from makesnrule where msr_makecode='" + MakeCode.Text + "' and msr_type='after'");
  69. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  70. string rangeafter = "0";
  71. if (dt.Rows.Count > 0)
  72. {
  73. rangeafter = dt.Rows[0]["aftersn_qty"].ToString();
  74. BaseUtil.SetFormValue(this.Controls, dt);
  75. }
  76. sql.Clear();
  77. sql.Append("select count(1) beforesn_qty from makesnlist where msl_makecode='" + MakeCode.Text + "' and msl_type='before'");
  78. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  79. if (dt.Rows.Count > 0)
  80. {
  81. rangebefore = dt.Rows[0]["beforesn_qty"].ToString();
  82. BaseUtil.SetFormValue(this.Controls, dt);
  83. }
  84. sql.Clear();
  85. sql.Append("select count(1) aftersn_qty from makesnlist where msl_makecode='" + MakeCode.Text + "' and msl_type='after'");
  86. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  87. if (dt.Rows.Count > 0)
  88. {
  89. rangeafter = dt.Rows[0]["aftersn_qty"].ToString();
  90. BaseUtil.SetFormValue(this.Controls, dt);
  91. }
  92. sql.Clear();
  93. sql.Append("select mcd_detno,mcd_stepcode,mcd_stepname,nvl(count(distinct A.ms_sncode),0) n,nvl(count(distinct B.ms_sncode),0) bn,(select nvl(count(distinct sp_sncode),0) from STEPPASSED where SP_MAKECODE = mcd_macode AND SP_STEPCODE = mcd_stepcode) inqty from MAKECRAFTdetail ");
  94. sql.Append("left join makeserial A on mcd_macode = A.ms_makecode and mcd_stepcode = ");
  95. sql.Append("A.ms_nextstepcode AND A.MS_STATUS = 1 LEFT JOIN MAKESERIAL B ON mcd_macode = B.ms_makecode AND MCD_STEPCODE = B.MS_STEPCODE AND B.MS_STATUS = 3 where mcd_macode = '" + MakeCode.Text + "' group by mcd_macode,mcd_detno, mcd_stepcode, mcd_stepname order by mcd_detno asc");
  96. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  97. if (dt.Rows.Count > 0)
  98. {
  99. BaseUtil.FillDgvWithDataTable(BOM, dt);
  100. }
  101. LogicHandler.DoCommandLog(Tag.ToString(), User.UserCode, MakeCode.Text, User.UserLineCode, User.UserSourceCode, "查询工单综合信息", "查询成功", "", "");
  102. }
  103. else MessageBox.Show("工单号不存在");
  104. }
  105. /// <summary>
  106. /// 清除DataGridView的数据
  107. /// </summary>
  108. /// <param name="dgv"></param>
  109. public static void CleanDGVData(DataGridView dgv)
  110. {
  111. for (int i = dgv.Rows.Count - 1; i >= 0; i--)
  112. {
  113. dgv.Rows.RemoveAt(i);
  114. }
  115. DataTable dt = dgv.DataSource as DataTable;
  116. if (dt != null)
  117. {
  118. dt.AcceptChanges();
  119. }
  120. }
  121. public static void CleanForm(Form Form)
  122. {
  123. for (int i = 0; i < Form.Controls.Count; i++)
  124. {
  125. if (Form.Controls[i].Controls.Count > 0)
  126. {
  127. CleanControls(Form.Controls[i].Controls);
  128. }
  129. if ((Form.Controls[i] is Label && GetCharInStringCount("_", Form.Controls[i].Name) != 2))
  130. Form.Controls[i].Text = "";
  131. if (Form.Controls[i] is DataGridView)
  132. CleanDGVData((DataGridView)Form.Controls[i]);
  133. }
  134. }
  135. public static void CleanControls(Control.ControlCollection collection)
  136. {
  137. for (int i = 0; i < collection.Count; i++)
  138. {
  139. if (collection[i].Controls.Count > 0)
  140. CleanControls(collection[i].Controls);
  141. if ((collection[i] is Label && GetCharInStringCount("_", collection[i].Name) != 2))
  142. collection[i].Text = "";
  143. if (collection[i] is DataGridView)
  144. CleanDGVData((DataGridView)collection[i]);
  145. }
  146. }
  147. public static int GetCharInStringCount(string Char, string String)
  148. {
  149. string str = String.Replace(Char, "");
  150. return (String.Length - str.Length) / Char.Length;
  151. }
  152. }
  153. }