094a155b93d57320a5fe926d29b403b670925fb9.svn-base 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. package xin.glue.ui.B.B02;
  2. import java.sql.CallableStatement;
  3. import java.sql.SQLException;
  4. import com.posdata.glue.biz.activity.PosActivity;
  5. import com.posdata.glue.biz.constants.PosBizControlConstants;
  6. import com.posdata.glue.context.PosContext;
  7. import com.posdata.glue.dao.PosGenericDao;
  8. import com.posdata.glue.dao.vo.PosParameter;
  9. import com.posdata.glue.dao.vo.PosRowSet;
  10. /**
  11. *
  12. * @Description 炉次或板坯牌号改判{界面ID:UIB020050}
  13. * @author 梅贵平{meiguiping}
  14. * @date 2009-4-8 下午04:20:36
  15. * @JDK Version jdk1.4.2
  16. */
  17. public class SaveChangeStlGrd extends PosActivity
  18. {
  19. public String runActivity(PosContext context)
  20. {
  21. PosGenericDao dao = this.getDao("mesdao");
  22. PosRowSet rowset = null;
  23. PosParameter param = null;
  24. CallableStatement cstm= null;
  25. String[] rowStatus = (String[])context.get("rowStatus");
  26. String[] CHARGE_NO = (String[])context.get("CHARGE_NO");//炉号或板坯号
  27. String[] INFO = (String[])context.get("INFO");//S为板坯,C为炉次
  28. String[] STL_GRD = (String[])context.get("STL_GRD");//厂内牌号
  29. String[] BEF_STL_GRD = (String[])context.get("BEF_STL_GRD");//原厂内牌号
  30. try
  31. {
  32. if(rowStatus != null)
  33. {
  34. int len = rowStatus.length;
  35. String infoProc= "";
  36. String infoSql = "";
  37. if("S".equals(INFO[0]))
  38. {
  39. // infoProc = "UIB020050_02.CALL_SLABNO";//板坯成分改判牌号后的判定
  40. cstm = dao.getCallableStatement("UIB020050_02.CALL_SLABNO");
  41. for(int i = 0; i < len; i++)
  42. {
  43. param = new PosParameter();
  44. param.setWhereClauseParameter(0, STL_GRD[i]);//厂内牌号
  45. param.setWhereClauseParameter(1, BEF_STL_GRD[i]);//原厂内牌号
  46. param.setWhereClauseParameter(2, CHARGE_NO[i]);//板坯号
  47. dao.update("UIB020050_03.UPDATE" , param);
  48. cstm.setString(1, CHARGE_NO[i]);
  49. cstm.setString(2, "2");
  50. cstm.registerOutParameter(3, java.sql.Types.VARCHAR);
  51. cstm.registerOutParameter(4, java.sql.Types.VARCHAR);
  52. cstm.execute();
  53. }
  54. }
  55. else
  56. {
  57. // infoProc = "UIB020050_01.CALL_CHARGENO";//炉次成分该判牌号后的判定
  58. cstm = dao.getCallableStatement("UIB020050_01.CALL_CHARGENO");
  59. for(int i = 0; i < len; i++)
  60. {
  61. param = new PosParameter();
  62. param.setWhereClauseParameter(0, STL_GRD[i]);//厂内牌号
  63. param.setWhereClauseParameter(1, BEF_STL_GRD[i]);//原厂内牌号
  64. param.setWhereClauseParameter(2, CHARGE_NO[i]);//炉号
  65. dao.update("UIB020050_01.UPDATE" , param);
  66. // add 0714 改判需要将余材
  67. param = new PosParameter();
  68. param.setWhereClauseParameter(0, STL_GRD[i]);
  69. param.setWhereClauseParameter(1, BEF_STL_GRD[i]);
  70. param.setWhereClauseParameter(2, CHARGE_NO[i]);
  71. dao.update("UIB020050_02.UPDATE" , param);
  72. //add 0714 改判需要将余材
  73. param = new PosParameter();
  74. param.setWhereClauseParameter(0, CHARGE_NO[i]);
  75. dao.update("UIB020050_03.UPDATE" , param);
  76. //add
  77. cstm.setString(1, CHARGE_NO[i]);
  78. cstm.registerOutParameter(2, java.sql.Types.VARCHAR);
  79. cstm.registerOutParameter(3, java.sql.Types.VARCHAR);
  80. cstm.execute();
  81. }
  82. }
  83. }
  84. }catch(Exception ex)
  85. {
  86. logger.logError(ex.getMessage(), ex);
  87. }finally
  88. {
  89. if (cstm != null)
  90. {
  91. try
  92. {
  93. cstm.close();
  94. }
  95. catch (SQLException e)
  96. {
  97. logger.logWarn(e.getMessage(), e);
  98. }
  99. }
  100. }
  101. return PosBizControlConstants.SUCCESS;
  102. }
  103. }