SlmBasePortInfoBll.cs 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Data;
  6. using CoreFS.CA06;
  7. using System.ComponentModel;
  8. using System.Drawing;
  9. using System.Windows.Forms;
  10. using Infragistics.Win.UltraWinGrid;
  11. using System.Collections;
  12. using ColumnDefine = Core.StlMes.Client.Sale.Common.TbColumnDefine.TbColumnDefine;
  13. namespace Core.StlMes.Client.Sale.BLL.SaleBusinessMgt.BaseData
  14. {
  15. public class SlmBasePortInfoBll : SaleBusinessMgt.BllBase.BaseBll
  16. {
  17. public SlmBasePortInfoBll(OpeBase ob)
  18. : base(ob)
  19. {
  20. }
  21. /// <summary>
  22. /// 查询入口
  23. /// </summary>
  24. /// <param name="sqlCondition"></param>
  25. /// <returns></returns>
  26. private DataSet GetSlmBasePortInfo(string sqlCondition)
  27. {
  28. string sqlStr = string.Format(SqlCollection.BaseData._QUERYSLMBASESTATION, sqlCondition, base.DateTimeTocharFormat);
  29. return base.ExecuteQuery(sqlStr);
  30. }
  31. /// <summary>
  32. /// 查询有效船运信息
  33. /// </summary>
  34. /// <param name="carType"></param>
  35. /// <returns></returns>
  36. public DataSet GetValidPortSlmBasePortInfo()
  37. {
  38. string sqlCondition = string.Format(" and cartype = '{0}' and validflag = '{1}'", "船运", "1");
  39. return GetSlmBasePortInfo(sqlCondition);
  40. }
  41. /// <summary>
  42. /// 查询无效船运信息
  43. /// </summary>
  44. /// <param name="carType"></param>
  45. /// <returns></returns>
  46. public DataSet GetNotValidPortSlmBasePortInfo()
  47. {
  48. string sqlCondition = string.Format(" and cartype = '{0}' and validflag = '{1}'", "船运", "0");
  49. return GetSlmBasePortInfo(sqlCondition);
  50. }
  51. /// <summary>
  52. /// 查询所有有效的信息(船运、汽运)
  53. /// </summary>
  54. /// <returns></returns>
  55. public DataSet GetValidSlmBasePortInfoAll()
  56. {
  57. string sqlCondition = string.Format(" and validflag = '{0}'", "1");
  58. return GetSlmBasePortInfo(sqlCondition);
  59. }
  60. /// <summary>
  61. /// 查询所有无效的信息(船运、汽运)
  62. /// </summary>
  63. /// <returns></returns>
  64. public DataSet GetNotValidSlmBasePortInfoAll()
  65. {
  66. string sqlCondition = string.Format(" and validflag = '{0}'", "0");
  67. return GetSlmBasePortInfo(sqlCondition);
  68. }
  69. /// <summary>
  70. /// 根据编号查询信息
  71. /// </summary>
  72. /// <param name="stationNo"></param>
  73. /// <returns></returns>
  74. public DataSet GetSlmBaseStationByStationNo(string stationNo)
  75. {
  76. string sqlCondition = string.Format(" and station_no = '{0}'", stationNo);
  77. return GetSlmBasePortInfo(sqlCondition);
  78. }
  79. /// <summary>
  80. /// 查询所有信息(有效、无效)
  81. /// </summary>
  82. /// <returns></returns>
  83. public DataSet GetSlmBaseStationAll()
  84. {
  85. return GetSlmBasePortInfo("");
  86. }
  87. /// <summary>
  88. /// 新增港口信息
  89. /// </summary>
  90. /// <param name="hs"></param>
  91. /// <param name="errMsg"></param>
  92. public void Insert(Hashtable hs,out string errMsg)
  93. {
  94. errMsg = "";
  95. hs.Add(ColumnDefine.SLM_BASE_STATION.STATION_NO, GetSlmBaseStationCode());
  96. CoreClientParam param = base.GetCoreClientParam(_ServerName, "portInsert", new object[] { hs });
  97. CoreClientParam result = base.fr.ExecuteNonQuery(param, CoreInvokeType.Internal);
  98. errMsg = base.GetReturnErrorInfo(result);
  99. }
  100. /// <summary>
  101. /// 修改港口信息
  102. /// </summary>
  103. /// <param name="hs"></param>
  104. /// <param name="errMsg"></param>
  105. public void Update(Hashtable hs, out string errMsg)
  106. {
  107. errMsg = "";
  108. CoreClientParam param = base.GetCoreClientParam(_ServerName, "portUpdate", new object[] { hs });
  109. CoreClientParam result = base.fr.ExecuteNonQuery(param, CoreInvokeType.Internal);
  110. errMsg = base.GetReturnErrorInfo(result);
  111. }
  112. /// <summary>
  113. /// 删除港口信息
  114. /// </summary>
  115. /// <param name="stationNo"></param>
  116. public void Delete(string stationNo,string deleteName,out string errMsg)
  117. {
  118. errMsg = "";
  119. CoreClientParam param = base.GetCoreClientParam(_ServerName, "portDelete", new object[] { stationNo,deleteName });
  120. CoreClientParam result = base.fr.ExecuteNonQuery(param, CoreInvokeType.Internal);
  121. errMsg = base.GetReturnErrorInfo(result);
  122. }
  123. /// <summary>
  124. /// 获取数据行数
  125. /// </summary>
  126. /// <returns></returns>
  127. private double GetCoutOfSlmBaseStation()
  128. {
  129. string sqlStr = "select count(1) from slm_base_station ";
  130. DataSet ds = base.ExecuteQuery(sqlStr);
  131. if (ds == null || ds.Tables.Count == 0 || ds.Tables[0].Rows.Count == 0)
  132. return 0;
  133. return Util.ConverObject.ConvertToDouble(ds.Tables[0].Rows[0][0]);
  134. }
  135. /// <summary>
  136. /// 自动生成客户编码
  137. /// </summary>
  138. /// <returns></returns>
  139. private string GetSlmBaseStationCode()
  140. {
  141. string customberno = "";
  142. string sqlStr = @"select *
  143. from (select lpad(l || '', 6, 0) customberno, a.station_no, rownum rn
  144. from (select level - 1 l from dual connect by level < {0}) b
  145. left join slm_base_station a on a.station_no =
  146. lpad(b.l || '', 6, 0)
  147. where a.station_no is null
  148. order by b.l)
  149. where rn = 1";
  150. sqlStr = string.Format(sqlStr, GetCoutOfSlmBaseStation() + 100);
  151. DataSet ds = base.ExecuteQuery(sqlStr);
  152. try
  153. {
  154. if (ds.Tables[0].Rows.Count == 0)
  155. customberno = "000001";
  156. else
  157. customberno = ds.Tables[0].Rows[0]["CUSTOMBERNO"].ToString();
  158. }
  159. catch
  160. {
  161. }
  162. return customberno;
  163. }
  164. private string _ServerName = "core.stlmes.server.sale.service.basedata.SlmBaseStation";
  165. }
  166. }