YtDataMappingObj.cs 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. using SysBaseLibs;
  2. using SysDataLibs.TableClass;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Data;
  6. using System.Linq;
  7. using System.Text;
  8. namespace SysDataLibs
  9. {
  10. public class YtDataMappingObj
  11. {
  12. public YtDataMappingObj()
  13. {
  14. CreateDataMapping();
  15. }
  16. DataTable _dtSpeicalMapping = null;
  17. DataTable _dtCheckTypeMapping = null;
  18. private void CreateDataMapping()
  19. {
  20. string lcSpecialsSql = " select * from v_ySpecials_Mapping ";
  21. string lcCheckTypeMappingSql = " select * from " + Tn.CheckProjectTypeMapping + " ";
  22. DBConnSql loDBConn = new DBConnSql();
  23. try
  24. {
  25. if (loDBConn.Open())
  26. {
  27. _dtSpeicalMapping = loDBConn.OpenDataTable(lcSpecialsSql);
  28. _dtCheckTypeMapping = loDBConn.OpenDataTable(lcCheckTypeMappingSql);
  29. }
  30. }
  31. catch (Exception err)
  32. {
  33. ThreadLog.LogException(err);
  34. }
  35. finally
  36. {
  37. loDBConn.Close();
  38. }
  39. //return lodt;
  40. }
  41. private string GetCheckItemMethodId(string pcCheckProjectId)
  42. {
  43. string lcRetval = "";
  44. if (CheckCach.CheckProjectCach.ContainsKey(pcCheckProjectId))
  45. {
  46. return CheckCach.CheckProjectCach[pcCheckProjectId];
  47. }
  48. DBConnSql loDbConn = new DBConnSql();
  49. try
  50. {
  51. if (loDbConn.Open())
  52. {
  53. rsQuery loQuery = loDbConn.OpenQuery("SELECT [CheckItemId],[CheckMethodId] FROM [CheckProjectType] WHERE [CheckProjectTypeID] =" + pcCheckProjectId);
  54. string lcItemId = loQuery.GetString("CheckItemId");
  55. //string lcMethodId = loQuery.GetString("CheckMethodId");
  56. lcRetval = lcItemId;
  57. }
  58. }
  59. catch (Exception err)
  60. {
  61. ThreadLog.LogException(err);
  62. }
  63. finally
  64. {
  65. loDbConn.Close();
  66. }
  67. if (!string.IsNullOrEmpty(lcRetval))
  68. {
  69. CheckCach.CheckProjectCach.Add(pcCheckProjectId, lcRetval);
  70. }
  71. return lcRetval;
  72. }
  73. public void Refresh()
  74. {
  75. //_dtSpeicalMapping.Clear();
  76. _dtSpeicalMapping = null;
  77. _dtCheckTypeMapping = null;
  78. CreateDataMapping();
  79. }
  80. /// <summary>
  81. /// 通过商品名称转换机构代码,获取第一个检索到的
  82. /// </summary>
  83. /// <param name="pcSpecalName">商品名称</param>
  84. /// <param name="pcMappingType">要转换的机构</param>
  85. /// <returns></returns>
  86. public string GetSpecialsMappingCode(string pcSpecalName, string pcLittleKindId, string pcMappingType)
  87. {
  88. string lcRetVal = "";
  89. //pcSpecalName = UtilStr.UAndT(pcSpecalName);
  90. if (_dtSpeicalMapping == null)
  91. {
  92. CreateDataMapping();
  93. }
  94. if (_dtSpeicalMapping != null)
  95. {
  96. DataRow[] drArr = _dtSpeicalMapping.Select("Name='" + pcSpecalName.Trim() + "' and LittleKindID='" + pcLittleKindId + "'");//
  97. if (drArr != null && drArr.Length > 0 && drArr[0][pcMappingType] != null)
  98. {
  99. lcRetVal = drArr[0][pcMappingType].ToString();
  100. }
  101. //lcRetVal =
  102. }
  103. // lcRetVal = _DiscList[pcCode];
  104. return lcRetVal;
  105. }
  106. public CheckProjectTypeMapping_info GetCheckTypeMapping(string CheckTypeID)
  107. {
  108. CheckProjectTypeMapping_info loCheckMapping = null;
  109. if (_dtCheckTypeMapping == null)
  110. {
  111. CreateDataMapping();
  112. }
  113. if (_dtCheckTypeMapping != null)
  114. {
  115. string checkItemId = GetCheckItemMethodId(CheckTypeID);
  116. DataRow[] drArr = _dtCheckTypeMapping.Select(CheckProjectTypeMapping_info.cCheckItemId + "='" + checkItemId.Trim() + "'");//
  117. if (drArr != null && drArr.Length > 0)
  118. {
  119. loCheckMapping = new CheckProjectTypeMapping_info();
  120. loCheckMapping.CheckItemId = drArr[0][CheckProjectTypeMapping_info.cCheckItemId].ToString();
  121. loCheckMapping.szCheckItemTypeLittleCode = drArr[0][CheckProjectTypeMapping_info.cszCheckItemTypeLittleCode].ToString();
  122. loCheckMapping.szCheckItemTypeGreatCode = drArr[0][CheckProjectTypeMapping_info.cszCheckItemTypeGreatCode].ToString();
  123. loCheckMapping.szCheckItemTypeContent = drArr[0][CheckProjectTypeMapping_info.cszCheckItemTypeContent].ToString();
  124. }
  125. }
  126. return loCheckMapping;
  127. }
  128. }
  129. internal class CheckCach
  130. {
  131. public static Dictionary<string, string> CheckProjectCach = new Dictionary<string, string>();
  132. }
  133. }