CDSVmsObjTypeF.cpp 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. //---------------------------------------------------------------------------
  2. #pragma hdrstop
  3. #include "CDSVmsObjTypeF.h"
  4. #include "AppGlobalF.h"
  5. //---------------------------------------------------------------------------
  6. #pragma package(smart_init)
  7. TVmsObjUse::TVmsObjUse()
  8. {
  9. }
  10. //---------------------------------------------------------------------------
  11. TVmsObjUse::~TVmsObjUse()
  12. {
  13. MODE = enUPDATE;
  14. }
  15. //---------------------------------------------------------------------------
  16. TVmsObjUseManager::TVmsObjUseManager()
  17. {
  18. }
  19. //---------------------------------------------------------------------------
  20. TVmsObjUseManager::~TVmsObjUseManager()
  21. {
  22. FLists.RemoveAll();
  23. }
  24. //---------------------------------------------------------------------------
  25. bool TVmsObjUseManager::LoadFromDb(String AFormId, TADOConnection *ADbConn/*=NULL*/)
  26. {
  27. return true;
  28. }
  29. //---------------------------------------------------------------------------
  30. //---------------------------------------------------------------------------
  31. TVmsObjType::TVmsObjType()
  32. {
  33. }
  34. //---------------------------------------------------------------------------
  35. TVmsObjType::~TVmsObjType()
  36. {
  37. FLists.RemoveAll();
  38. }
  39. //---------------------------------------------------------------------------
  40. //---------------------------------------------------------------------------
  41. TVmsObjTypeManager *VmsObjTypeManager = NULL;
  42. //---------------------------------------------------------------------------
  43. TVmsObjTypeManager::TVmsObjTypeManager()
  44. {
  45. }
  46. //---------------------------------------------------------------------------
  47. TVmsObjTypeManager::~TVmsObjTypeManager()
  48. {
  49. FLists.RemoveAll();
  50. }
  51. //---------------------------------------------------------------------------
  52. bool TVmsObjTypeManager::LoadFromDb(TADOConnection *ADbConn/*=NULL*/)
  53. {
  54. String sQry;
  55. TADOQuery *pADO = NULL;
  56. try
  57. {
  58. FLists.Lock();
  59. FLists.RemoveAll();
  60. }
  61. __finally
  62. {
  63. FLists.UnLock();
  64. }
  65. sQry = "SELECT VMS_FORM_TYPE_CD AS TYPE, \r\n"
  66. " VMS_FORM_OBJECT_TYPE_CD AS CD, \r\n"
  67. " VMS_FORM_OBJECT_TYPE_NM AS NM, \r\n"
  68. " EDTN_CD \r\n"
  69. " FROM TB_VMS_FORM_OBJECT_TYPE \r\n"
  70. " ORDER BY TYPE, CD \r\n";
  71. try
  72. {
  73. FLists.Lock();
  74. try
  75. {
  76. pADO = new TADOQuery(NULL);
  77. pADO->Close();
  78. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  79. pADO->SQL->Clear();
  80. pADO->SQL->Text = sQry;
  81. pADO->Open();
  82. for( ; !pADO->Eof; pADO->Next())
  83. {
  84. String sUse = pADO->FieldByName("EDTN_CD")->AsString;
  85. if (sUse == "EDI2") continue;
  86. int nFormType = pADO->FieldByName("TYPE")->AsInteger;
  87. TVmsObjType *pObj = FLists.Find(nFormType);
  88. if (!pObj)
  89. {
  90. pObj = new TVmsObjType();
  91. FLists.Push(nFormType, pObj);
  92. }
  93. pObj->TYPE = nFormType;
  94. int nType = pADO->FieldByName("CD")->AsInteger;
  95. TFormObjType *pType = pObj->FLists.Find(nType);
  96. if (!pType)
  97. {
  98. pType = new TFormObjType();
  99. pObj->FLists.Push(nType, pType);
  100. }
  101. pType->TYPE = pADO->FieldByName("CD")->AsInteger;
  102. pType->NAME = pADO->FieldByName("NM")->AsString;
  103. pType->EDTN_CD = sUse;
  104. }
  105. }
  106. catch(EDatabaseError &E)
  107. {
  108. DBERRORMSG("VMS폼객체유형조회", String(E.ClassName()), E.Message, sQry);
  109. throw Exception(String(E.ClassName()) + E.Message);
  110. }
  111. catch(Exception &e)
  112. {
  113. DBERRORMSG("VMS폼객체유형조회", String(e.ClassName()), e.Message, sQry);
  114. throw Exception(String(e.ClassName()) + e.Message);
  115. }
  116. }
  117. __finally
  118. {
  119. if (pADO)
  120. {
  121. pADO->Close();
  122. delete pADO;
  123. }
  124. FLists.UnLock();
  125. }
  126. return true;
  127. }
  128. //---------------------------------------------------------------------------