CDSPrkPlceF.cpp 79 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575
  1. //---------------------------------------------------------------------------
  2. #pragma hdrstop
  3. #include "CDSPrkPlceF.h"
  4. #include "ITS_OPLibF.h"
  5. //---------------------------------------------------------------------------
  6. #pragma package(smart_init)
  7. TPrkPlce::TPrkPlce()
  8. {
  9. FOPR = new TPrkPlceOpr();
  10. }
  11. //---------------------------------------------------------------------------
  12. TPrkPlce::~TPrkPlce()
  13. {
  14. }
  15. //---------------------------------------------------------------------------
  16. //---------------------------------------------------------------------------
  17. TPrkPlceManager *PrkPlceManager = NULL;
  18. //---------------------------------------------------------------------------
  19. /*
  20. * PrltPrk Manager
  21. */
  22. TPrkPlceManager::TPrkPlceManager()
  23. {
  24. }
  25. //---------------------------------------------------------------------------
  26. TPrkPlceManager::~TPrkPlceManager()
  27. {
  28. FLists.RemoveAll();
  29. }
  30. //---------------------------------------------------------------------------
  31. bool TPrkPlceManager::LoadFromDb(TADOConnection *ADbConn/*=NULL*/)
  32. {
  33. String sQry;
  34. TADOQuery *pADO = NULL;
  35. sQry = "SELECT * \r\n"
  36. " FROM TB_PRK_PLCE \r\n"
  37. " WHERE pis_type != 'N' \r\n"
  38. " AND del_yn = 'N' \r\n";
  39. FLists.Lock();
  40. try
  41. {
  42. FLists.RemoveAll();
  43. try
  44. {
  45. pADO = new TADOQuery(NULL);
  46. pADO->Close();
  47. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  48. pADO->SQL->Clear();
  49. pADO->SQL->Text = sQry;
  50. pADO->Prepared = true;
  51. pADO->Open();
  52. for( ; !pADO->Eof; pADO->Next())
  53. {
  54. TPrkPlce *pObj = new TPrkPlce();
  55. pObj->CTLR_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString;
  56. pObj->CTLR_ID = pADO->FieldByName("PRK_PLCE_MANAGE_NO")->AsString;
  57. pObj->PRK_PLCE_STTUS_VER = pADO->FieldByName("PRK_PLCE_STTUS_VER")->AsString;
  58. pObj->NAME = pADO->FieldByName("PRK_PLCE_NM")->AsString;
  59. pObj->ISTL_LCTN_NM = pADO->FieldByName("PRK_PLCE_NM")->AsString;
  60. pObj->ISTL_LCTN_ADDR = pADO->FieldByName("PRK_PLCE_ADRES")->AsString.Trim();
  61. pObj->VMS_DSPL_NM = pADO->FieldByName("VMS_DSPL_NM")->AsString;
  62. //pObj->PRK_PLCE_ADRES = pADO->FieldByName("PRK_PLCE_ADRES")->AsString;
  63. pObj->PRK_PLCE_INSTL_DE = pADO->FieldByName("PRK_PLCE_INSTL_DE")->AsString;
  64. pObj->PRK_PLCE_ABL_DE = pADO->FieldByName("PRK_PLCE_ABL_DE")->AsString;
  65. pObj->PRK_PLCE_ENTRC_NM = pADO->FieldByName("PRK_PLCE_ENTRC_NM")->AsString;
  66. //pObj->PRK_PLCE_ENTRC_LA = pADO->FieldByName("PRK_PLCE_ENTRC_LA")->AsString;
  67. //pObj->PRK_PLCE_ENTRC_LO = pADO->FieldByName("PRK_PLCE_ENTRC_LO")->AsString;
  68. pObj->PRK_PLCE_ENTRC_EXTTY = pADO->FieldByName("PRK_PLCE_ENTRC_EXTTY")->AsInteger;
  69. pObj->PARKING_TY = pADO->FieldByName("PARKING_TY")->AsInteger;
  70. pObj->PARKING_US = pADO->FieldByName("PARKING_US")->AsInteger;
  71. pObj->AR_LEVEL_SE = pADO->FieldByName("AR_LEVEL_SE")->AsInteger;
  72. //pObj->PRK_PLCE_IMAGE_DATA = pADO->FieldByName("PRK_PLCE_IMAGE_DATA")->AsString;
  73. pObj->PRK_PLCE_IMAGE_TYPE = pADO->FieldByName("PRK_PLCE_IMAGE_TYPE")->AsInteger;
  74. pObj->PRK_PLCE_IMAGE_DC = pADO->FieldByName("PRK_PLCE_IMAGE_DC")->AsString;
  75. pObj->SYS_NE = pADO->FieldByName("SYS_NE")->AsString;
  76. pObj->PARKING_CNTRL_SYS_INSTL_DE = pADO->FieldByName("PARKING_CNTRL_SYS_INSTL_DE")->AsString;
  77. pObj->RELATION_LAW_AND_ORDINANCES = pADO->FieldByName("RELATION_LAW_AND_ORDINANCES")->AsString;
  78. pObj->PRK_AVAIL_CARTYPE = pADO->FieldByName("PRK_AVAIL_CARTYPE")->AsString;
  79. pObj->PRK_CMPRT_CO = pADO->FieldByName("PRK_CMPRT_CO")->AsInteger;
  80. pObj->COLCT_DEVICE_INSTL_AT = pADO->FieldByName("COLCT_DEVICE_INSTL_AT")->AsInteger;
  81. pObj->MASTER_CONTROLLER = pADO->FieldByName("MASTER_CONTROLLER")->AsInteger;
  82. pObj->SLAVE_CONTROLLER = pADO->FieldByName("SLAVE_CONTROLLER")->AsInteger;
  83. pObj->COLCT_DEVICE_QTY = pADO->FieldByName("COLCT_DEVICE_QTY")->AsInteger;
  84. pObj->COLCT_DEVICE_KND = pADO->FieldByName("COLCT_DEVICE_KND")->AsString;
  85. //pObj->TYPE_IMGAGE = pADO->FieldByName("TYPE_IMGAGE")->AsInteger;
  86. //pObj->TYPE_GEOMAGNETIC = pADO->FieldByName("TYPE_GEOMAGNETIC")->AsInteger;
  87. //pObj->TYPE_RADAR = pADO->FieldByName("TYPE_RADAR")->AsInteger;
  88. //pObj->TYPE_LOOP = pADO->FieldByName("TYPE_LOOP")->AsInteger;
  89. //pObj->TYPE_ULTRASONIC = pADO->FieldByName("TYPE_ULTRASONIC")->AsInteger;
  90. //pObj->TYPE_ETC = pADO->FieldByName("TYPE_ETC")->AsInteger;
  91. pObj->COLCT_DEVICE_INSTL_DE = pADO->FieldByName("COLCT_DEVICE_INSTL_DE")->AsString;
  92. pObj->CRM_PRV_CCTV_INSTL_AT = pADO->FieldByName("CRM_PRV_CCTV_INSTL_AT")->AsInteger;
  93. pObj->CRM_PRV_CCTV_INSTL_CO = pADO->FieldByName("CRM_PRV_CCTV_INSTL_CO")->AsInteger;
  94. pObj->INFO_CREATE_TIME = pADO->FieldByName("INFO_CREATE_TIME")->AsString;
  95. //pObj->PIS_TYPE = pADO->FieldByName("PIS_TYPE")->AsString;
  96. pObj->DEL_YN = pADO->FieldByName("DEL_YN")->AsString;
  97. pObj->TYPE_CD = pADO->FieldByName("PIS_TYPE")->AsString.Trim();
  98. pObj->X_CRDN = pADO->FieldByName("PRK_PLCE_ENTRC_LO")->AsFloat;
  99. pObj->Y_CRDN = pADO->FieldByName("PRK_PLCE_ENTRC_LA")->AsFloat;
  100. pObj->DEL_YN = pADO->FieldByName("DEL_YN")->AsString.Trim();
  101. pObj->OPR_INFO = pADO->FieldByName("OPR_INFO")->AsString.Trim();
  102. FLists.Push(pObj->CTLR_NMBR, pObj);
  103. pObj->Completed = true;
  104. pObj->MEM_DEL = "N";
  105. }
  106. }
  107. catch(EDatabaseError &E)
  108. {
  109. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  110. DBERRORMSG("TPrkPlceManager::LoadFromDb", String(E.ClassName()), E.Message, sQry);
  111. throw Exception(String(E.ClassName()) + E.Message);
  112. }
  113. catch(Exception &exception)
  114. {
  115. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  116. DBERRORMSG("TPrkPlceManager::LoadFromDb", String(exception.ClassName()), exception.Message, sQry);
  117. throw Exception(String(exception.ClassName()) + exception.Message);
  118. }
  119. }
  120. __finally
  121. {
  122. if (pADO)
  123. {
  124. pADO->Close();
  125. delete pADO;
  126. }
  127. FLists.UnLock();
  128. }
  129. LoadFromDbOpr(ADbConn);
  130. LoadFromDbFlr(ADbConn);
  131. return true;
  132. }
  133. //---------------------------------------------------------------------------
  134. bool TPrkPlceManager::LoadStatusFromDb(TADOConnection *ADbConn/*=NULL*/)
  135. {
  136. String sQry;
  137. TADOQuery *pADO = NULL;
  138. sQry = "SELECT * \r\n"
  139. " FROM TB_PRK_PLCE_STTS A, TB_PRK_PLCE B \r\n"
  140. " WHERE B.pis_type != 'N' \r\n"
  141. " AND B.del_yn = 'N' \r\n"
  142. " AND A.prk_plce_nmbr = B.prk_plce_nmbr \r\n"
  143. " AND A.UPDT_DT >= TO_CHAR(SYSDATE-5/1440, 'YYYYMMDDHH24MISS') \r\n";
  144. FLists.Lock();
  145. try
  146. {
  147. TPrkPlce *pObj = NULL;
  148. try
  149. {
  150. pADO = new TADOQuery(NULL);
  151. pADO->Close();
  152. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  153. pADO->SQL->Clear();
  154. pADO->SQL->Text = sQry;
  155. pADO->Prepared = true;
  156. pADO->Open();
  157. //int nRows = pADO->RecordCount;
  158. for( ; !pADO->Eof; pADO->Next())
  159. {
  160. String sPrltNmbr = pADO->FieldByName("prk_plce_nmbr")->AsString;
  161. pObj = FLists.Find(sPrltNmbr);
  162. if (!pObj) continue;
  163. String UPDT_DT = pADO->FieldByName("UPDT_DT")->AsString;
  164. String CONN_STTS_CD = pADO->FieldByName("CMNC_STTS_CD")->AsString;
  165. if (CONN_STTS_CD != "CMS0")
  166. {
  167. pObj->STATE.Comm = park_comm_error;
  168. //통신장애
  169. continue;
  170. }
  171. pObj->STATE.Comm = park_comm_normal;
  172. }
  173. }
  174. catch(EDatabaseError &E)
  175. {
  176. DBERRORMSG("TPrkPlceManager::LoadStatusFromDb", String(E.ClassName()), E.Message, sQry);
  177. throw Exception(String(E.ClassName()) + E.Message);
  178. }
  179. catch(Exception &e)
  180. {
  181. DBERRORMSG("TPrkPlceManager::LoadStatusFromDb", String(e.ClassName()), e.Message, sQry);
  182. throw Exception(String(e.ClassName()) + e.Message);
  183. }
  184. }
  185. __finally
  186. {
  187. if (pADO)
  188. {
  189. pADO->Close();
  190. delete pADO;
  191. }
  192. FLists.UnLock();
  193. }
  194. return true;
  195. }
  196. //---------------------------------------------------------------------------
  197. bool TPrkPlceManager::LoadFromDbOpr(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  198. {
  199. String sQry;
  200. TADOQuery *pADO = NULL;
  201. sQry = "SELECT A.* \r\n"
  202. " FROM TB_PRK_PLCE_OPR A \r\n"
  203. " WHERE A.prk_plce_nmbr = :p01 \r\n";
  204. try
  205. {
  206. try
  207. {
  208. pADO = new TADOQuery(NULL);
  209. pADO->Close();
  210. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  211. pADO->SQL->Clear();
  212. pADO->SQL->Text = sQry;
  213. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  214. pADO->Prepared = true;
  215. pADO->Open();
  216. for( ; !pADO->Eof; pADO->Next())
  217. {
  218. AObj->FOPR->PRK_PLCE_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString; // N NUMBER(10) N 주차장 관리 번호
  219. AObj->FOPR->PRK_PLCE_OPR_VER = pADO->FieldByName("PRK_PLCE_OPR_VER")->AsString; // N VARCHAR2(10) Y 주차운영 정보버전
  220. AObj->FOPR->CMPT_INST_NM = pADO->FieldByName("CMPT_INST_NM")->AsString; // N VARCHAR2(32) Y 관할기관명
  221. AObj->FOPR->OPER_DEPT_NM = pADO->FieldByName("OPER_DEPT_NM")->AsString; // N VARCHAR2(32) Y 운영기관 정보 - 운영부서명
  222. AObj->FOPR->OPER_PERSON_NM = pADO->FieldByName("OPER_PERSON_NM")->AsString; // N VARCHAR2(10) Y 운영기관 정보 - 운영기관 담당자
  223. AObj->FOPR->OPER_CTT_PC_TEL = pADO->FieldByName("OPER_CTT_PC_TEL")->AsString; // N VARCHAR2(13) Y 운영기관 정보 - 운영담당자 전화번호
  224. AObj->FOPR->OPER_CTT_PC_EMAIL = pADO->FieldByName("OPER_CTT_PC_EMAIL")->AsString; // N VARCHAR2(50) Y 운영기관 정보 - 운영담당자 이메일
  225. AObj->FOPR->NO_DRV_DAY_OPERTN_AT = pADO->FieldByName("NO_DRV_DAY_OPERTN_AT")->AsInteger; // N NUMBER(1) Y 주차 부제 시행여부 (0 : 미시행, 1 : 2부제, 2 : 5부제, 3 : 10부제, 4 : 승용차요일제, 9 : 기타)
  226. AObj->FOPR->OPERTN_BS_FREE_TIME = pADO->FieldByName("OPERTN_BS_FREE_TIME")->AsString; // N VARCHAR2(8) Y 기본무료 시간, 주차장 회차 (기본 무료) (00:30:00)
  227. AObj->FOPR->OPN_CODE = pADO->FieldByName("OPN_CODE")->AsInteger; // N NUMBER(1) Y 개방코드, 운영시간 외 무료 개방 (0 : 미개방, 1 : 개방)
  228. AObj->FOPR->PARKING_CHRGE_EXCCLC_MTHD = pADO->FieldByName("PARKING_CHRGE_EXCCLC_MTHD")->AsInteger; // N NUMBER(1) Y 주차요금 정산 방식 (0 : 유인정산, 1 : 무인정산, 2 : 혼합정산, 9 : 기타)
  229. AObj->FOPR->PARKING_CHRGE_PYMNT_MN = pADO->FieldByName("PARKING_CHRGE_PYMNT_MN")->AsString; // N VARCHAR2(8) Y 주차요금 지불수단 - 아래 유형 조합해서 생성됌 - 예시) 현금/신용카드 혼합결제 시 (11000000), 핀테크 결제 시 (00000100), 1: 현금, 2: 신용카드, 3: 교통카드, 4: 전자지불(하이패스), 5: 휴대폰소액결제, 6: 핀테크(OO페이), 7: MaaS 통합결제, 9: 기타
  230. AObj->FOPR->PARKING_RESVE_OPERTN_AT = pADO->FieldByName("PARKING_RESVE_OPERTN_AT")->AsInteger; // N NUMBER(1) Y 주차예약 시행여부 (0 : 미시행, 1 : 시행-주차장, 2 : 시행-주차구역, 3 : 시행-주차면)
  231. AObj->FOPR->PARTCLR_MATTER = pADO->FieldByName("PARTCLR_MATTER")->AsString; // N VARCHAR2(128) Y 특이사항
  232. AObj->FOPR->INFO_CREATE_TIME = pADO->FieldByName("INFO_CREATE_TIME")->AsString; // N VARCHAR2(14) Y 주차정보를 입력하여 생성하는 시각, (YYYY-MM-DD hh:mm:ss)
  233. }
  234. }
  235. catch(EDatabaseError &E)
  236. {
  237. DBERRORMSG("TPrkPlceManager::LoadFromDbOpr", String(E.ClassName()), E.Message, sQry);
  238. throw Exception(String(E.ClassName()) + E.Message);
  239. }
  240. catch(Exception &e)
  241. {
  242. DBERRORMSG("TPrkPlceManager::LoadFromDbOpr", String(e.ClassName()), e.Message, sQry);
  243. throw Exception(String(e.ClassName()) + e.Message);
  244. }
  245. }
  246. __finally
  247. {
  248. if (pADO)
  249. {
  250. pADO->Close();
  251. delete pADO;
  252. }
  253. }
  254. return true;
  255. }
  256. //---------------------------------------------------------------------------
  257. bool TPrkPlceManager::LoadFromDbOpr(TADOConnection *ADbConn/*=NULL*/)
  258. {
  259. String sQry;
  260. TADOQuery *pADO = NULL;
  261. sQry = "SELECT A.* \r\n"
  262. " FROM TB_PRK_PLCE_OPR A \r\n";
  263. try
  264. {
  265. try
  266. {
  267. pADO = new TADOQuery(NULL);
  268. pADO->Close();
  269. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  270. pADO->SQL->Clear();
  271. pADO->SQL->Text = sQry;
  272. pADO->Prepared = true;
  273. pADO->Open();
  274. for( ; !pADO->Eof; pADO->Next())
  275. {
  276. String PRK_PLCE_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString;
  277. TPrkPlce *AObj = FLists.Find(PRK_PLCE_NMBR);
  278. if (AObj == NULL) {
  279. continue;
  280. }
  281. AObj->FOPR->PRK_PLCE_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString; // N NUMBER(10) N 주차장 관리 번호
  282. AObj->FOPR->PRK_PLCE_OPR_VER = pADO->FieldByName("PRK_PLCE_OPR_VER")->AsString; // N VARCHAR2(10) Y 주차운영 정보버전
  283. AObj->FOPR->CMPT_INST_NM = pADO->FieldByName("CMPT_INST_NM")->AsString; // N VARCHAR2(32) Y 관할기관명
  284. AObj->FOPR->OPER_DEPT_NM = pADO->FieldByName("OPER_DEPT_NM")->AsString; // N VARCHAR2(32) Y 운영기관 정보 - 운영부서명
  285. AObj->FOPR->OPER_PERSON_NM = pADO->FieldByName("OPER_PERSON_NM")->AsString; // N VARCHAR2(10) Y 운영기관 정보 - 운영기관 담당자
  286. AObj->FOPR->OPER_CTT_PC_TEL = pADO->FieldByName("OPER_CTT_PC_TEL")->AsString; // N VARCHAR2(13) Y 운영기관 정보 - 운영담당자 전화번호
  287. AObj->FOPR->OPER_CTT_PC_EMAIL = pADO->FieldByName("OPER_CTT_PC_EMAIL")->AsString; // N VARCHAR2(50) Y 운영기관 정보 - 운영담당자 이메일
  288. AObj->FOPR->NO_DRV_DAY_OPERTN_AT = pADO->FieldByName("NO_DRV_DAY_OPERTN_AT")->AsInteger; // N NUMBER(1) Y 주차 부제 시행여부 (0 : 미시행, 1 : 2부제, 2 : 5부제, 3 : 10부제, 4 : 승용차요일제, 9 : 기타)
  289. AObj->FOPR->OPERTN_BS_FREE_TIME = pADO->FieldByName("OPERTN_BS_FREE_TIME")->AsString; // N VARCHAR2(8) Y 기본무료 시간, 주차장 회차 (기본 무료) (00:30:00)
  290. AObj->FOPR->OPN_CODE = pADO->FieldByName("OPN_CODE")->AsInteger; // N NUMBER(1) Y 개방코드, 운영시간 외 무료 개방 (0 : 미개방, 1 : 개방)
  291. AObj->FOPR->PARKING_CHRGE_EXCCLC_MTHD = pADO->FieldByName("PARKING_CHRGE_EXCCLC_MTHD")->AsInteger; // N NUMBER(1) Y 주차요금 정산 방식 (0 : 유인정산, 1 : 무인정산, 2 : 혼합정산, 9 : 기타)
  292. AObj->FOPR->PARKING_CHRGE_PYMNT_MN = pADO->FieldByName("PARKING_CHRGE_PYMNT_MN")->AsString; // N VARCHAR2(8) Y 주차요금 지불수단 - 아래 유형 조합해서 생성됌 - 예시) 현금/신용카드 혼합결제 시 (11000000), 핀테크 결제 시 (00000100), 1: 현금, 2: 신용카드, 3: 교통카드, 4: 전자지불(하이패스), 5: 휴대폰소액결제, 6: 핀테크(OO페이), 7: MaaS 통합결제, 9: 기타
  293. AObj->FOPR->PARKING_RESVE_OPERTN_AT = pADO->FieldByName("PARKING_RESVE_OPERTN_AT")->AsInteger; // N NUMBER(1) Y 주차예약 시행여부 (0 : 미시행, 1 : 시행-주차장, 2 : 시행-주차구역, 3 : 시행-주차면)
  294. AObj->FOPR->PARTCLR_MATTER = pADO->FieldByName("PARTCLR_MATTER")->AsString; // N VARCHAR2(128) Y 특이사항
  295. AObj->FOPR->INFO_CREATE_TIME = pADO->FieldByName("INFO_CREATE_TIME")->AsString; // N VARCHAR2(14) Y 주차정보를 입력하여 생성하는 시각, (YYYY-MM-DD hh:mm:ss)
  296. }
  297. }
  298. catch(EDatabaseError &E)
  299. {
  300. DBERRORMSG("TPrkPlceManager::LoadFromDbOpr", String(E.ClassName()), E.Message, sQry);
  301. throw Exception(String(E.ClassName()) + E.Message);
  302. }
  303. catch(Exception &e)
  304. {
  305. DBERRORMSG("TPrkPlceManager::LoadFromDbOpr", String(e.ClassName()), e.Message, sQry);
  306. throw Exception(String(e.ClassName()) + e.Message);
  307. }
  308. }
  309. __finally
  310. {
  311. if (pADO)
  312. {
  313. pADO->Close();
  314. delete pADO;
  315. }
  316. }
  317. return true;
  318. }
  319. //---------------------------------------------------------------------------
  320. bool TPrkPlceManager::LoadFromDbOprChrge(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  321. {
  322. String sQry;
  323. TADOQuery *pADO = NULL;
  324. sQry = "SELECT A.* \r\n"
  325. " FROM TB_PRK_PLCE_OPR_CHRGE A \r\n"
  326. " WHERE A.prk_plce_nmbr = :p01 \r\n";
  327. try
  328. {
  329. try
  330. {
  331. pADO = new TADOQuery(NULL);
  332. pADO->Close();
  333. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  334. pADO->SQL->Clear();
  335. pADO->SQL->Text = sQry;
  336. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  337. pADO->Prepared = true;
  338. pADO->Open();
  339. for( ; !pADO->Eof; pADO->Next())
  340. {
  341. int CHRGE = pADO->FieldByName("CHRGE")->AsInteger;
  342. TPrkPlceOprChrge *pChrge = AObj->FOPR->FChrges.Find(CHRGE);
  343. if (pChrge == NULL) {
  344. pChrge = new TPrkPlceOprChrge();
  345. pChrge->PRK_PLCE_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString;
  346. pChrge->CHRGE = CHRGE;
  347. AObj->FOPR->FChrges.Push(CHRGE, pChrge);
  348. }
  349. pChrge->PARKING_CHRGE_BS_TIME = pADO->FieldByName("PARKING_CHRGE_BS_TIME")->AsInteger;
  350. pChrge->PARKING_CHRGE_BS_CHRGE = pADO->FieldByName("PARKING_CHRGE_BS_CHRGE")->AsInteger;
  351. pChrge->PARKING_CHRGE_ADIT_UNIT_TIME = pADO->FieldByName("PARKING_CHRGE_ADIT_UNIT_TIME")->AsInteger;
  352. pChrge->PARKING_CHRGE_ADIT_UNIT_CHRGE = pADO->FieldByName("PARKING_CHRGE_ADIT_UNIT_CHRGE")->AsInteger;
  353. }
  354. }
  355. catch(EDatabaseError &E)
  356. {
  357. DBERRORMSG("TPrkPlceManager::LoadFromDbOprChrge", String(E.ClassName()), E.Message, sQry);
  358. throw Exception(String(E.ClassName()) + E.Message);
  359. }
  360. catch(Exception &e)
  361. {
  362. DBERRORMSG("TPrkPlceManager::LoadFromDbOprChrge", String(e.ClassName()), e.Message, sQry);
  363. throw Exception(String(e.ClassName()) + e.Message);
  364. }
  365. }
  366. __finally
  367. {
  368. if (pADO)
  369. {
  370. pADO->Close();
  371. delete pADO;
  372. }
  373. }
  374. return true;
  375. }
  376. //---------------------------------------------------------------------------
  377. bool TPrkPlceManager::LoadFromDbOprSched(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  378. {
  379. String sQry;
  380. TADOQuery *pADO = NULL;
  381. sQry = "SELECT A.* \r\n"
  382. " FROM TB_PRK_PLCE_OPR_SCHED A \r\n"
  383. " WHERE A.prk_plce_nmbr = :p01 \r\n";
  384. try
  385. {
  386. try
  387. {
  388. pADO = new TADOQuery(NULL);
  389. pADO->Close();
  390. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  391. pADO->SQL->Clear();
  392. pADO->SQL->Text = sQry;
  393. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  394. pADO->Prepared = true;
  395. pADO->Open();
  396. for( ; !pADO->Eof; pADO->Next())
  397. {
  398. int SCHED = pADO->FieldByName("SCHED")->AsInteger;
  399. TPrkPlceOprSched *pSched = AObj->FOPR->FScheds.Find(SCHED);
  400. if (pSched == NULL) {
  401. pSched = new TPrkPlceOprSched();
  402. pSched->PRK_PLCE_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString;
  403. pSched->SCHED = SCHED;
  404. AObj->FOPR->FScheds.Push(SCHED, pSched);
  405. }
  406. pSched->OPERTN_START_TIME = pADO->FieldByName("OPERTN_START_TIME")->AsString;
  407. pSched->OPERTN_END_TIME = pADO->FieldByName("OPERTN_END_TIME")->AsString;
  408. pSched->PARKING_CHRGE_LEVY_AT = pADO->FieldByName("PARKING_CHRGE_LEVY_AT")->AsInteger;
  409. }
  410. }
  411. catch(EDatabaseError &E)
  412. {
  413. DBERRORMSG("TPrkPlceManager::LoadFromDbOprSched", String(E.ClassName()), E.Message, sQry);
  414. throw Exception(String(E.ClassName()) + E.Message);
  415. }
  416. catch(Exception &e)
  417. {
  418. DBERRORMSG("TPrkPlceManager::LoadFromDbOprSched", String(e.ClassName()), e.Message, sQry);
  419. throw Exception(String(e.ClassName()) + e.Message);
  420. }
  421. }
  422. __finally
  423. {
  424. if (pADO)
  425. {
  426. pADO->Close();
  427. delete pADO;
  428. }
  429. }
  430. return true;
  431. }
  432. //---------------------------------------------------------------------------
  433. bool TPrkPlceManager::LoadFromDbFlr(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  434. {
  435. String sQry;
  436. TADOQuery *pADO = NULL;
  437. sQry = "SELECT A.PRK_PLCE_NMBR, A.FLR_NO, \r\n"
  438. " A.FLR_PRK_CMPRT_CO, \r\n"
  439. " A.FLR_REMNDR_PRK_CMPRT_CO, \r\n"
  440. " A.DATA_COLCT_TIME \r\n"
  441. " FROM TB_PRK_PLCE_FLR A \r\n"
  442. " WHERE A.prk_plce_nmbr = :p01 \r\n";
  443. try
  444. {
  445. //AObj->FFlrs.Clear();
  446. try
  447. {
  448. pADO = new TADOQuery(NULL);
  449. pADO->Close();
  450. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  451. pADO->SQL->Clear();
  452. pADO->SQL->Text = sQry;
  453. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  454. pADO->Prepared = true;
  455. pADO->Open();
  456. for( ; !pADO->Eof; pADO->Next())
  457. {
  458. String PRK_PLCE_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString; // N NUMBER(10) N 주차장 관리 번호
  459. String FLR_NO = pADO->FieldByName("FLR_NO")->AsString; // N VARCHAR2(10) N 층 번호
  460. int FLR_PRK_CMPRT_CO = pADO->FieldByName("FLR_PRK_CMPRT_CO")->AsInteger; // N NUMBER(18) Y 층별 주차구획 수, 120(면), 시설정보+ 실시간정보
  461. int FLR_REMNDR_PRK_CMPRT_CO = pADO->FieldByName("FLR_REMNDR_PRK_CMPRT_CO")->AsInteger; // N NUMBER(18) Y 층별 잔여 주차구획 수, 120(면), 실시간정보
  462. String DATA_COLCT_TIME = pADO->FieldByName("DATA_COLCT_TIME")->AsString; // N VARCHAR2(14) Y 실시간 주차데이터 수집시간 (YYYY-MM-DD hh:mm:ss)
  463. TPrkPlceFlr *pFlr = AObj->FFlrs.Find(FLR_NO);
  464. if (pFlr == NULL) {
  465. pFlr = new TPrkPlceFlr();
  466. pFlr->PRK_PLCE_NMBR = PRK_PLCE_NMBR;
  467. pFlr->FLR_NO = FLR_NO;
  468. AObj->FFlrs.Push(FLR_NO, pFlr);
  469. }
  470. pFlr->FLR_PRK_CMPRT_CO = FLR_PRK_CMPRT_CO;
  471. pFlr->FLR_REMNDR_PRK_CMPRT_CO = FLR_REMNDR_PRK_CMPRT_CO;
  472. pFlr->DATA_COLCT_TIME = DATA_COLCT_TIME;
  473. }
  474. }
  475. catch(EDatabaseError &E)
  476. {
  477. DBERRORMSG("TPrkPlceManager::LoadFromDbFlr", String(E.ClassName()), E.Message, sQry);
  478. throw Exception(String(E.ClassName()) + E.Message);
  479. }
  480. catch(Exception &e)
  481. {
  482. DBERRORMSG("TPrkPlceManager::LoadFromDbFlr", String(e.ClassName()), e.Message, sQry);
  483. throw Exception(String(e.ClassName()) + e.Message);
  484. }
  485. }
  486. __finally
  487. {
  488. if (pADO)
  489. {
  490. pADO->Close();
  491. delete pADO;
  492. }
  493. }
  494. return true;
  495. }
  496. //---------------------------------------------------------------------------
  497. bool TPrkPlceManager::LoadFromDbFlr(TADOConnection *ADbConn/*=NULL*/)
  498. {
  499. String sQry;
  500. TADOQuery *pADO = NULL;
  501. sQry = "SELECT A.PRK_PLCE_NMBR, A.FLR_NO, \r\n"
  502. " A.FLR_PRK_CMPRT_CO, \r\n"
  503. " A.FLR_REMNDR_PRK_CMPRT_CO, \r\n"
  504. " A.DATA_COLCT_TIME \r\n"
  505. " FROM TB_PRK_PLCE_FLR A \r\n";
  506. try
  507. {
  508. //AObj->FFlrs.Clear();
  509. try
  510. {
  511. pADO = new TADOQuery(NULL);
  512. pADO->Close();
  513. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  514. pADO->SQL->Clear();
  515. pADO->SQL->Text = sQry;
  516. pADO->Prepared = true;
  517. pADO->Open();
  518. for( ; !pADO->Eof; pADO->Next())
  519. {
  520. String PRK_PLCE_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString; // N NUMBER(10) N 주차장 관리 번호
  521. String FLR_NO = pADO->FieldByName("FLR_NO")->AsString; // N VARCHAR2(10) N 층 번호
  522. int FLR_PRK_CMPRT_CO = pADO->FieldByName("FLR_PRK_CMPRT_CO")->AsInteger; // N NUMBER(18) Y 층별 주차구획 수, 120(면), 시설정보+ 실시간정보
  523. int FLR_REMNDR_PRK_CMPRT_CO = pADO->FieldByName("FLR_REMNDR_PRK_CMPRT_CO")->AsInteger; // N NUMBER(18) Y 층별 잔여 주차구획 수, 120(면), 실시간정보
  524. String DATA_COLCT_TIME = pADO->FieldByName("DATA_COLCT_TIME")->AsString; // N VARCHAR2(14) Y 실시간 주차데이터 수집시간 (YYYY-MM-DD hh:mm:ss)
  525. TPrkPlce *AObj = FLists.Find(PRK_PLCE_NMBR);
  526. if (AObj == NULL) {
  527. continue;
  528. }
  529. TPrkPlceFlr *pFlr = AObj->FFlrs.Find(FLR_NO);
  530. if (pFlr == NULL) {
  531. pFlr = new TPrkPlceFlr();
  532. pFlr->PRK_PLCE_NMBR = PRK_PLCE_NMBR;
  533. pFlr->FLR_NO = FLR_NO;
  534. AObj->FFlrs.Push(FLR_NO, pFlr);
  535. }
  536. pFlr->FLR_PRK_CMPRT_CO = FLR_PRK_CMPRT_CO;
  537. pFlr->FLR_REMNDR_PRK_CMPRT_CO = FLR_REMNDR_PRK_CMPRT_CO;
  538. pFlr->DATA_COLCT_TIME = DATA_COLCT_TIME;
  539. }
  540. }
  541. catch(EDatabaseError &E)
  542. {
  543. DBERRORMSG("TPrkPlceManager::LoadFromDbFlr", String(E.ClassName()), E.Message, sQry);
  544. throw Exception(String(E.ClassName()) + E.Message);
  545. }
  546. catch(Exception &e)
  547. {
  548. DBERRORMSG("TPrkPlceManager::LoadFromDbFlr", String(e.ClassName()), e.Message, sQry);
  549. throw Exception(String(e.ClassName()) + e.Message);
  550. }
  551. }
  552. __finally
  553. {
  554. if (pADO)
  555. {
  556. pADO->Close();
  557. delete pADO;
  558. }
  559. }
  560. return true;
  561. }
  562. //---------------------------------------------------------------------------
  563. bool TPrkPlceManager::LoadFromDbFlrDev(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  564. {
  565. String sQry;
  566. TADOQuery *pADO = NULL;
  567. sQry = "SELECT A.* \r\n"
  568. " FROM TB_PRK_PLCE_FLR_DEV A \r\n"
  569. " WHERE A.prk_plce_nmbr = :p01 \r\n"
  570. " ORDER BY A.PRK_PLCE_NMBR, A.FLR_NO, TO_NUMBER(A.DEVICE_ID) \r\n";
  571. try
  572. {
  573. //AObj->FFlrs.Clear();
  574. try
  575. {
  576. pADO = new TADOQuery(NULL);
  577. pADO->Close();
  578. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  579. pADO->SQL->Clear();
  580. pADO->SQL->Text = sQry;
  581. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  582. pADO->Prepared = true;
  583. pADO->Open();
  584. for( ; !pADO->Eof; pADO->Next())
  585. {
  586. String PRK_PLCE_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString; // N NUMBER(10) N 주차장 관리 번호
  587. String FLR_NO = pADO->FieldByName("FLR_NO")->AsString; // N VARCHAR2(10) N 층 번호
  588. int DEVICE_ID = pADO->FieldByName("DEVICE_ID")->AsInteger; // N VARCHAR2(5) N 주차정보수집장치 ID
  589. int X_POS = pADO->FieldByName("X_POS")->AsInteger; // N NUMBER(4) Y 0 이미지 좌표 X
  590. int Y_POS = pADO->FieldByName("Y_POS")->AsInteger; // N NUMBER(4) Y 0 이미지 좌표 Y
  591. TPrkPlceFlr *pFlr = AObj->FFlrs.Find(FLR_NO);
  592. if (pFlr != NULL) {
  593. // 무조건 주차장 층 정보가 존재해야 한다.
  594. TPrkPlceFlrDev *pFlrDev = pFlr->FFlrDevs.Find(DEVICE_ID);
  595. if (pFlrDev == NULL) {
  596. pFlrDev = new TPrkPlceFlrDev();
  597. pFlrDev->PRK_PLCE_NMBR = PRK_PLCE_NMBR;
  598. pFlrDev->FLR_NO = FLR_NO;
  599. pFlrDev->DEVICE_ID = DEVICE_ID;
  600. pFlr->FFlrDevs.Push(DEVICE_ID, pFlrDev);
  601. }
  602. pFlrDev->X_POS = X_POS;
  603. pFlrDev->Y_POS = Y_POS;
  604. }
  605. }
  606. }
  607. catch(EDatabaseError &E)
  608. {
  609. DBERRORMSG("TPrkPlceManager::LoadFromDbFlrDev", String(E.ClassName()), E.Message, sQry);
  610. throw Exception(String(E.ClassName()) + E.Message);
  611. }
  612. catch(Exception &e)
  613. {
  614. DBERRORMSG("TPrkPlceManager::LoadFromDbFlrDev", String(e.ClassName()), e.Message, sQry);
  615. throw Exception(String(e.ClassName()) + e.Message);
  616. }
  617. }
  618. __finally
  619. {
  620. if (pADO)
  621. {
  622. pADO->Close();
  623. delete pADO;
  624. }
  625. }
  626. return true;
  627. }
  628. //---------------------------------------------------------------------------
  629. bool TPrkPlceManager::LoadFromDbAr(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  630. {
  631. String sQry;
  632. TADOQuery *pADO = NULL;
  633. sQry = "SELECT A.* \r\n"
  634. " FROM TB_PRK_PLCE_AR A \r\n"
  635. " WHERE A.prk_plce_nmbr = :p01 \r\n";
  636. try
  637. {
  638. //FOR_STL(TPrkPlceFlr *, pFlr, AObj->FFlrs)
  639. //{
  640. // pFlr->FArs.Clear();
  641. //}
  642. try
  643. {
  644. pADO = new TADOQuery(NULL);
  645. pADO->Close();
  646. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  647. pADO->SQL->Clear();
  648. pADO->SQL->Text = sQry;
  649. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  650. pADO->Prepared = true;
  651. pADO->Open();
  652. for( ; !pADO->Eof; pADO->Next())
  653. {
  654. String PRK_PLCE_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString; // N NUMBER(10) N 주차장 관리 번호
  655. String FLR_NO = pADO->FieldByName("FLR_NO")->AsString; // N VARCHAR2(10) N 층 번호
  656. String AR_NO = pADO->FieldByName("AR_NO")->AsString; // N VARCHAR2(10) N 구역 일련번호
  657. int AR_PRK_CMPRT_CO = pADO->FieldByName("AR_PRK_CMPRT_CO")->AsInteger; // N NUMBER(18) Y 구역별 주차 구획 수, 120(면), 시설정보+실시간정보
  658. int AR_REMNDR_PRK_CMPRT_CO = pADO->FieldByName("AR_REMNDR_PRK_CMPRT_CO")->AsInteger; // N NUMBER(18) Y 구역별 잔여 주차 구획 수, 120(면), 실시간정보
  659. TPrkPlceFlr *pFlr = AObj->FFlrs.Find(FLR_NO);
  660. if (pFlr) {
  661. TPrkPlceAr *pAr = pFlr->FArs.Find(AR_NO);
  662. if (pAr == NULL) {
  663. pAr = new TPrkPlceAr();
  664. pAr->PRK_PLCE_NMBR = PRK_PLCE_NMBR;
  665. pAr->FLR_NO = FLR_NO;
  666. pAr->AR_NO = AR_NO;
  667. pFlr->FArs.Push(AR_NO, pAr);
  668. }
  669. pAr->AR_PRK_CMPRT_CO = AR_PRK_CMPRT_CO;
  670. pAr->AR_REMNDR_PRK_CMPRT_CO = AR_REMNDR_PRK_CMPRT_CO;
  671. }
  672. }
  673. }
  674. catch(EDatabaseError &E)
  675. {
  676. DBERRORMSG("TPrkPlceManager::LoadFromDbAr", String(E.ClassName()), E.Message, sQry);
  677. throw Exception(String(E.ClassName()) + E.Message);
  678. }
  679. catch(Exception &e)
  680. {
  681. DBERRORMSG("TPrkPlceManager::LoadFromDbAr", String(e.ClassName()), e.Message, sQry);
  682. throw Exception(String(e.ClassName()) + e.Message);
  683. }
  684. }
  685. __finally
  686. {
  687. if (pADO)
  688. {
  689. pADO->Close();
  690. delete pADO;
  691. }
  692. }
  693. return true;
  694. }
  695. //---------------------------------------------------------------------------
  696. bool TPrkPlceManager::LoadFromDbPrv(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  697. {
  698. String sQry;
  699. TADOQuery *pADO = NULL;
  700. sQry = "SELECT A.* \r\n"
  701. " FROM TB_PRK_PLCE_PRV A \r\n"
  702. " WHERE A.prk_plce_nmbr = :p01 \r\n";
  703. try
  704. {
  705. //AObj->FPrvs.Clear();
  706. try
  707. {
  708. pADO = new TADOQuery(NULL);
  709. pADO->Close();
  710. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  711. pADO->SQL->Clear();
  712. pADO->SQL->Text = sQry;
  713. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  714. pADO->Prepared = true;
  715. pADO->Open();
  716. for( ; !pADO->Eof; pADO->Next())
  717. {
  718. String PRK_PLCE_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString; // N NUMBER(10) N 주차장 관리 번호
  719. int VHCTY_AR_SE = pADO->FieldByName("VHCTY_AR_SE")->AsInteger; // N NUMBER(1) N 전용주차구역 구분 (0: 경차 전용, 1: 친환경차 (전기차), 2: 화물차 전용, 3: 긴급차량 전용, 4: 장애인 전용, 5: 어르신 전용, 6: 여성 전용, 9: 기타)
  720. int VHCTY_AR_PRK_CMPRT_CO = pADO->FieldByName("VHCTY_AR_PRK_CMPRT_CO")->AsInteger; // N NUMBER(18) Y 전용주차구역별 주차 구획 수, 시설정보+실시간정보
  721. int VHCTY_AR_REMNDR_PRK_CMPRT_CO = pADO->FieldByName("VHCTY_AR_REMNDR_PRK_CMPRT_CO")->AsInteger; // N NUMBER(18) Y 전용주차구역별 잔여 주차 구획 수, 실시간정보
  722. TPrkPlcePrv *pPrv = AObj->FPrvs.Find(VHCTY_AR_SE);
  723. if (pPrv == NULL) {
  724. pPrv = new TPrkPlcePrv();
  725. pPrv->PRK_PLCE_NMBR = PRK_PLCE_NMBR;
  726. pPrv->VHCTY_AR_SE = VHCTY_AR_SE;
  727. AObj->FPrvs.Push(VHCTY_AR_SE, pPrv);
  728. }
  729. pPrv->VHCTY_AR_PRK_CMPRT_CO = VHCTY_AR_PRK_CMPRT_CO;
  730. pPrv->VHCTY_AR_REMNDR_PRK_CMPRT_CO = VHCTY_AR_REMNDR_PRK_CMPRT_CO;
  731. }
  732. }
  733. catch(EDatabaseError &E)
  734. {
  735. DBERRORMSG("TPrkPlceManager::LoadFromDbPrv", String(E.ClassName()), E.Message, sQry);
  736. throw Exception(String(E.ClassName()) + E.Message);
  737. }
  738. catch(Exception &e)
  739. {
  740. DBERRORMSG("TPrkPlceManager::LoadFromDbPrv", String(e.ClassName()), e.Message, sQry);
  741. throw Exception(String(e.ClassName()) + e.Message);
  742. }
  743. }
  744. __finally
  745. {
  746. if (pADO)
  747. {
  748. pADO->Close();
  749. delete pADO;
  750. }
  751. }
  752. return true;
  753. }
  754. //---------------------------------------------------------------------------
  755. bool TPrkPlceManager::LoadFromDbDev(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  756. {
  757. String sQry;
  758. TADOQuery *pADO = NULL;
  759. sQry = "SELECT A.* \r\n"
  760. " FROM TB_PRK_PLCE_DEV A \r\n"
  761. " WHERE A.prk_plce_nmbr = :p01 \r\n"
  762. " ORDER BY A.PRK_PLCE_NMBR, TO_NUMBER(A.DEVICE_ID) \r\n";
  763. try
  764. {
  765. try
  766. {
  767. pADO = new TADOQuery(NULL);
  768. pADO->Close();
  769. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  770. pADO->SQL->Clear();
  771. pADO->SQL->Text = sQry;
  772. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  773. pADO->Prepared = true;
  774. pADO->Open();
  775. for( ; !pADO->Eof; pADO->Next())
  776. {
  777. String PRK_PLCE_NMBR = pADO->FieldByName("PRK_PLCE_NMBR")->AsString; // N NUMBER(10) N 주차장 관리 번호
  778. int DEVICE_ID = pADO->FieldByName("DEVICE_ID")->AsInteger; // N VARCHAR2(5) N 주차정보수집장치 ID
  779. int DEVICE_TYPE = pADO->FieldByName("DEVICE_TYPE")->AsInteger; // N NUMBER(1) Y 주차정보수집장치 종류 (0 : 영상식, 1 : 지자기, 2 : 레이더, 3 : 루프, 4 : 초음파, 9 : 기타)
  780. String PRK_UNIT_ID = pADO->FieldByName("PRK_UNIT_ID")->AsString; // N VARCHAR2(10) Y 주차면 ID, 층번호+구역일련번호 예시) 1FA01 1층 A구역 01번 주차면
  781. int TYPED_PARKING_LOTS = pADO->FieldByName("TYPED_PARKING_LOTS")->AsInteger; // N NUMBER(1) Y 주차면 유형 (0 : 일반, 1 : 경차 전용, 2 : 대형(화물)전용, 3 : 긴급차량전용, 4 : 장애인 전용, 5 : 여성 전용, 9 : 기타)
  782. int OCCUPATION = pADO->FieldByName("OCCUPATION")->AsInteger; // N NUMBER(1) Y 주차면 점유여부 (0 : 주차가능 (주차면 비점유), 1 : 주차불가 (주차면 점유))
  783. int CONNECTED = pADO->FieldByName("CONNECTED")->AsInteger; // N NUMBER(1) Y 통신상태 (0 : 불량, 1 : 정상)
  784. TPrkPlceDev *pDev = AObj->FDevs.Find(DEVICE_ID);
  785. if (pDev == NULL) {
  786. pDev = new TPrkPlceDev();
  787. pDev->PRK_PLCE_NMBR = PRK_PLCE_NMBR;
  788. pDev->DEVICE_ID = DEVICE_ID;
  789. pDev->DEVICE_TYPE = DEVICE_TYPE;
  790. pDev->PRK_UNIT_ID = PRK_UNIT_ID;
  791. AObj->FDevs.Push(DEVICE_ID, pDev);
  792. }
  793. pDev->TYPED_PARKING_LOTS = TYPED_PARKING_LOTS;
  794. pDev->OCCUPATION = OCCUPATION;
  795. pDev->CONNECTED = CONNECTED;
  796. }
  797. }
  798. catch(EDatabaseError &E)
  799. {
  800. DBERRORMSG("TPrkPlceManager::LoadFromDbDev", String(E.ClassName()), E.Message, sQry);
  801. throw Exception(String(E.ClassName()) + E.Message);
  802. }
  803. catch(Exception &e)
  804. {
  805. DBERRORMSG("TPrkPlceManager::LoadFromDbDev", String(e.ClassName()), e.Message, sQry);
  806. throw Exception(String(e.ClassName()) + e.Message);
  807. }
  808. }
  809. __finally
  810. {
  811. if (pADO)
  812. {
  813. pADO->Close();
  814. delete pADO;
  815. }
  816. }
  817. return true;
  818. }
  819. //---------------------------------------------------------------------------
  820. bool TPrkPlceManager::GetNextPrkNmbr(int &ANmbr, int &AId, TADOConnection *ADbConn/*=NULL*/)
  821. {
  822. String sQry;
  823. TADOQuery *pADO = NULL;
  824. sQry = "SELECT NVL(MAX(prk_plce_nmbr), 0) + 1 AS NEWID FROM TB_PRK_PLCE";
  825. try
  826. {
  827. try
  828. {
  829. pADO = new TADOQuery(NULL);
  830. pADO->Close();
  831. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  832. pADO->SQL->Clear();
  833. pADO->SQL->Text = sQry;
  834. pADO->Prepared = true;
  835. pADO->Open();
  836. ANmbr = pADO->FieldByName("NEWID")->AsInteger;
  837. AId = ANmbr / 10000;
  838. return true;
  839. }
  840. catch(EDatabaseError &E)
  841. {
  842. DBERRORLOG("TPrkPlceManager::GetNextPrkNmbr", String(E.ClassName()), E.Message, sQry);
  843. throw Exception(String(E.ClassName()) + E.Message);
  844. }
  845. catch(Exception &e)
  846. {
  847. DBERRORLOG("TPrkPlceManager::GetNextPrkNmbr", String(e.ClassName()), e.Message, sQry);
  848. throw Exception(String(e.ClassName()) + e.Message);
  849. }
  850. }
  851. __finally
  852. {
  853. if (pADO)
  854. {
  855. pADO->Close();
  856. delete pADO;
  857. }
  858. }
  859. return false;
  860. }
  861. //---------------------------------------------------------------------------
  862. bool TPrkPlceManager::DeletePrkPlce(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  863. {
  864. String sQry;
  865. TADOQuery *pADO = NULL;
  866. sQry = "UPDATE TB_PRK_PLCE \r\n"
  867. " SET DEL_YN = 'Y' \r\n"
  868. " WHERE prk_plce_nmbr = :p01 \r\n";
  869. try
  870. {
  871. FLists.Lock();
  872. try
  873. {
  874. pADO = new TADOQuery(NULL);
  875. pADO->Close();
  876. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  877. pADO->SQL->Clear();
  878. pADO->SQL->Text = sQry;
  879. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  880. pADO->ExecSQL();
  881. sQry = "DELETE TB_FCLT_INFR \r\n"
  882. " WHERE FCLT_ID = :p01 \r\n";
  883. " AND FCLT_TYPE = 'PARK' \r\n";
  884. pADO->SQL->Clear();
  885. pADO->SQL->Text = sQry;
  886. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_ID;
  887. pADO->ExecSQL();
  888. return true;
  889. }
  890. catch(EDatabaseError &E)
  891. {
  892. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  893. DBERRORMSG("TPrkPlceManager::DeletePrkPlce", String(E.ClassName()), E.Message, sQry);
  894. throw Exception(String(E.ClassName()) + E.Message);
  895. }
  896. catch(Exception &exception)
  897. {
  898. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  899. DBERRORMSG("TPrkPlceManager::DeletePrkPlce", String(exception.ClassName()), exception.Message, sQry);
  900. throw Exception(String(exception.ClassName()) + exception.Message);
  901. }
  902. }
  903. __finally
  904. {
  905. if (pADO)
  906. {
  907. pADO->Close();
  908. delete pADO;
  909. }
  910. FLists.UnLock();
  911. }
  912. return true;
  913. }
  914. //---------------------------------------------------------------------------
  915. bool TPrkPlceManager::InsertPrkPlce(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  916. {
  917. return MergePrkPlce(AObj, ADbConn);
  918. }
  919. //---------------------------------------------------------------------------
  920. bool TPrkPlceManager::UpdatePrkPlceOprInfo(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  921. {
  922. String sQry;
  923. TADOQuery *pADO = NULL;
  924. sQry = "UPDATE TB_PRK_PLCE \r\n"
  925. " SET PRK_PLCE_NM = :p02, \r\n"
  926. " PRK_PLCE_ADRES = :p03, \r\n"
  927. " OPR_INFO = :p04 \r\n"
  928. " WHERE PRK_PLCE_NMBR = :p01 \r\n";
  929. try
  930. {
  931. try
  932. {
  933. pADO = new TADOQuery(NULL);
  934. pADO->Close();
  935. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  936. pADO->SQL->Clear();
  937. pADO->SQL->Text = sQry;
  938. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  939. pADO->Parameters->ParamByName("p02")->Value = AObj->NAME;
  940. pADO->Parameters->ParamByName("p03")->Value = AObj->ISTL_LCTN_ADDR;
  941. pADO->Parameters->ParamByName("p04")->Value = AObj->OPR_INFO;
  942. pADO->ExecSQL();
  943. }
  944. catch(EDatabaseError &E)
  945. {
  946. DBERRORMSG("TPrkPlceManager::UpdatePrkPlceOprInfo", String(E.ClassName()), E.Message, sQry);
  947. throw Exception(String(E.ClassName()) + E.Message);
  948. }
  949. catch(Exception &e)
  950. {
  951. DBERRORMSG("TPrkPlceManager::UpdatePrkPlceOprInfo", String(e.ClassName()), e.Message, sQry);
  952. throw Exception(String(e.ClassName()) + e.Message);
  953. }
  954. }
  955. __finally
  956. {
  957. if (pADO)
  958. {
  959. pADO->Close();
  960. delete pADO;
  961. }
  962. }
  963. return true;
  964. }
  965. //---------------------------------------------------------------------------
  966. bool TPrkPlceManager::UpdatePrkPlce(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  967. {
  968. return MergePrkPlce(AObj, ADbConn);
  969. }
  970. //---------------------------------------------------------------------------
  971. bool TPrkPlceManager::MergePrkPlce(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  972. {
  973. String sQry;
  974. TADOQuery *pADO = NULL;
  975. sQry = "MERGE INTO TB_PRK_PLCE L \r\n"
  976. "USING (SELECT \r\n"
  977. " :p01 AS PRK_PLCE_NMBR, \r\n"
  978. " :p02 AS PRK_PLCE_MANAGE_NO, \r\n"
  979. " :p03 AS PRK_PLCE_STTUS_VER, \r\n"
  980. " :p04 AS PRK_PLCE_NM, \r\n"
  981. " :p44 AS VMS_DSPL_NM, \r\n"
  982. " :p05 AS PRK_PLCE_ADRES, \r\n"
  983. " :p06 AS PRK_PLCE_INSTL_DE, \r\n"
  984. " :p07 AS PRK_PLCE_ABL_DE, \r\n"
  985. " :p08 AS PRK_PLCE_ENTRC_NM, \r\n"
  986. " :p09 AS PRK_PLCE_ENTRC_LA, \r\n"
  987. " :p10 AS PRK_PLCE_ENTRC_LO, \r\n"
  988. " :p11 AS PRK_PLCE_ENTRC_EXTTY, \r\n"
  989. " :p12 AS PARKING_TY, \r\n"
  990. " :p13 AS PARKING_US, \r\n"
  991. " :p14 AS AR_LEVEL_SE, \r\n"
  992. //" :p15 AS PRK_PLCE_IMAGE_DATA, \r\n"
  993. " :p16 AS PRK_PLCE_IMAGE_TYPE, \r\n"
  994. " :p17 AS PRK_PLCE_IMAGE_DC, \r\n"
  995. " :p18 AS SYS_NE, \r\n"
  996. " :p19 AS PARKING_CNTRL_SYS_INSTL_DE, \r\n"
  997. " :p20 AS RELATION_LAW_AND_ORDINANCES, \r\n"
  998. " :p21 AS PRK_AVAIL_CARTYPE, \r\n"
  999. " :p22 AS PRK_CMPRT_CO, \r\n"
  1000. " :p23 AS COLCT_DEVICE_INSTL_AT, \r\n"
  1001. " :p24 AS MASTER_CONTROLLER, \r\n"
  1002. " :p25 AS SLAVE_CONTROLLER, \r\n"
  1003. " :p26 AS COLCT_DEVICE_QTY, \r\n"
  1004. " :p27 AS COLCT_DEVICE_KND, \r\n"
  1005. //" :p28 AS TYPE_IMGAGE, \r\n"
  1006. //" :p29 AS TYPE_GEOMAGNETIC, \r\n"
  1007. //" :p30 AS TYPE_RADAR, \r\n"
  1008. //" :p31 AS TYPE_LOOP, \r\n"
  1009. //" :p32 AS TYPE_ULTRASONIC, \r\n"
  1010. //" :p33 AS TYPE_ETC, \r\n"
  1011. " :p34 AS COLCT_DEVICE_INSTL_DE, \r\n"
  1012. " :p35 AS CRM_PRV_CCTV_INSTL_AT, \r\n"
  1013. " :p36 AS CRM_PRV_CCTV_INSTL_CO, \r\n"
  1014. " :p37 AS PIS_TYPE, \r\n"
  1015. " :p38 AS INFO_CREATE_TIME \r\n"
  1016. " FROM DUAL) M \r\n"
  1017. " ON (L.PRK_PLCE_NMBR = M.PRK_PLCE_NMBR) \r\n"
  1018. "WHEN MATCHED THEN \r\n"
  1019. " UPDATE SET \r\n"
  1020. " L.PRK_PLCE_MANAGE_NO = M.PRK_PLCE_MANAGE_NO, \r\n"
  1021. " L.PRK_PLCE_STTUS_VER = M.PRK_PLCE_STTUS_VER, \r\n"
  1022. " L.PRK_PLCE_NM = M.PRK_PLCE_NM, \r\n"
  1023. " L.VMS_DSPL_NM = M.VMS_DSPL_NM, \r\n"
  1024. " L.PRK_PLCE_ADRES = M.PRK_PLCE_ADRES, \r\n"
  1025. " L.PRK_PLCE_INSTL_DE = M.PRK_PLCE_INSTL_DE, \r\n"
  1026. " L.PRK_PLCE_ABL_DE = M.PRK_PLCE_ABL_DE, \r\n"
  1027. " L.PRK_PLCE_ENTRC_NM = M.PRK_PLCE_ENTRC_NM, \r\n"
  1028. " L.PRK_PLCE_ENTRC_LA = M.PRK_PLCE_ENTRC_LA, \r\n"
  1029. " L.PRK_PLCE_ENTRC_LO = M.PRK_PLCE_ENTRC_LO, \r\n"
  1030. " L.PRK_PLCE_ENTRC_EXTTY = M.PRK_PLCE_ENTRC_EXTTY, \r\n"
  1031. " L.PARKING_TY = M.PARKING_TY, \r\n"
  1032. " L.PARKING_US = M.PARKING_US, \r\n"
  1033. " L.AR_LEVEL_SE = M.AR_LEVEL_SE, \r\n"
  1034. //" L.PRK_PLCE_IMAGE_DATA = M.PRK_PLCE_IMAGE_DATA, \r\n"
  1035. " L.PRK_PLCE_IMAGE_TYPE = M.PRK_PLCE_IMAGE_TYPE, \r\n"
  1036. " L.PRK_PLCE_IMAGE_DC = M.PRK_PLCE_IMAGE_DC, \r\n"
  1037. " L.SYS_NE = M.SYS_NE, \r\n"
  1038. " L.PARKING_CNTRL_SYS_INSTL_DE = M.PARKING_CNTRL_SYS_INSTL_DE, \r\n"
  1039. " L.RELATION_LAW_AND_ORDINANCES = M.RELATION_LAW_AND_ORDINANCES, \r\n"
  1040. " L.PRK_AVAIL_CARTYPE = M.PRK_AVAIL_CARTYPE, \r\n"
  1041. " L.PRK_CMPRT_CO = M.PRK_CMPRT_CO, \r\n"
  1042. " L.COLCT_DEVICE_INSTL_AT = M.COLCT_DEVICE_INSTL_AT, \r\n"
  1043. " L.MASTER_CONTROLLER = M.MASTER_CONTROLLER, \r\n"
  1044. " L.SLAVE_CONTROLLER = M.SLAVE_CONTROLLER, \r\n"
  1045. " L.COLCT_DEVICE_QTY = M.COLCT_DEVICE_QTY, \r\n"
  1046. " L.COLCT_DEVICE_KND = M.COLCT_DEVICE_KND, \r\n"
  1047. //" L.TYPE_IMGAGE = M.TYPE_IMGAGE, \r\n"
  1048. //" L.TYPE_GEOMAGNETIC = M.TYPE_GEOMAGNETIC, \r\n"
  1049. //" L.TYPE_RADAR = M.TYPE_RADAR, \r\n"
  1050. //" L.TYPE_LOOP = M.TYPE_LOOP, \r\n"
  1051. //" L.TYPE_ULTRASONIC = M.TYPE_ULTRASONIC, \r\n"
  1052. //" L.TYPE_ETC = M.TYPE_ETC, \r\n"
  1053. " L.COLCT_DEVICE_INSTL_DE = M.COLCT_DEVICE_INSTL_DE, \r\n"
  1054. " L.CRM_PRV_CCTV_INSTL_AT = M.CRM_PRV_CCTV_INSTL_AT, \r\n"
  1055. " L.CRM_PRV_CCTV_INSTL_CO = M.CRM_PRV_CCTV_INSTL_CO, \r\n"
  1056. " L.PIS_TYPE = M.PIS_TYPE, \r\n"
  1057. " L.INFO_CREATE_TIME = M.INFO_CREATE_TIME \r\n"
  1058. "WHEN NOT MATCHED THEN \r\n"
  1059. " INSERT ( \r\n"
  1060. " PRK_PLCE_NMBR, \r\n"
  1061. " PRK_PLCE_MANAGE_NO, \r\n"
  1062. " PRK_PLCE_STTUS_VER, \r\n"
  1063. " PRK_PLCE_NM, \r\n"
  1064. " VMS_DSPL_NM, \r\n"
  1065. " PRK_PLCE_ADRES, \r\n"
  1066. " PRK_PLCE_INSTL_DE, \r\n"
  1067. " PRK_PLCE_ABL_DE, \r\n"
  1068. " PRK_PLCE_ENTRC_NM, \r\n"
  1069. " PRK_PLCE_ENTRC_LA, \r\n"
  1070. " PRK_PLCE_ENTRC_LO, \r\n"
  1071. " PRK_PLCE_ENTRC_EXTTY, \r\n"
  1072. " PARKING_TY, \r\n"
  1073. " PARKING_US, \r\n"
  1074. " AR_LEVEL_SE, \r\n"
  1075. //" PRK_PLCE_IMAGE_DATA, \r\n"
  1076. " PRK_PLCE_IMAGE_TYPE, \r\n"
  1077. " PRK_PLCE_IMAGE_DC, \r\n"
  1078. " SYS_NE, \r\n"
  1079. " PARKING_CNTRL_SYS_INSTL_DE, \r\n"
  1080. " RELATION_LAW_AND_ORDINANCES, \r\n"
  1081. " PRK_AVAIL_CARTYPE, \r\n"
  1082. " PRK_CMPRT_CO, \r\n"
  1083. " COLCT_DEVICE_INSTL_AT, \r\n"
  1084. " MASTER_CONTROLLER, \r\n"
  1085. " SLAVE_CONTROLLER, \r\n"
  1086. " COLCT_DEVICE_QTY, \r\n"
  1087. " COLCT_DEVICE_KND, \r\n"
  1088. //" TYPE_IMGAGE, \r\n"
  1089. //" TYPE_GEOMAGNETIC, \r\n"
  1090. //" TYPE_RADAR, \r\n"
  1091. //" TYPE_LOOP, \r\n"
  1092. //" TYPE_ULTRASONIC, \r\n"
  1093. //" TYPE_ETC, \r\n"
  1094. " COLCT_DEVICE_INSTL_DE, \r\n"
  1095. " CRM_PRV_CCTV_INSTL_AT, \r\n"
  1096. " CRM_PRV_CCTV_INSTL_CO, \r\n"
  1097. " PIS_TYPE, \r\n"
  1098. " INFO_CREATE_TIME ) \r\n"
  1099. " VALUES ( \r\n"
  1100. " M.PRK_PLCE_NMBR, \r\n"
  1101. " M.PRK_PLCE_MANAGE_NO, \r\n"
  1102. " M.PRK_PLCE_STTUS_VER, \r\n"
  1103. " M.PRK_PLCE_NM, \r\n"
  1104. " M.VMS_DSPL_NM, \r\n"
  1105. " M.PRK_PLCE_ADRES, \r\n"
  1106. " M.PRK_PLCE_INSTL_DE, \r\n"
  1107. " M.PRK_PLCE_ABL_DE, \r\n"
  1108. " M.PRK_PLCE_ENTRC_NM, \r\n"
  1109. " M.PRK_PLCE_ENTRC_LA, \r\n"
  1110. " M.PRK_PLCE_ENTRC_LO, \r\n"
  1111. " M.PRK_PLCE_ENTRC_EXTTY, \r\n"
  1112. " M.PARKING_TY, \r\n"
  1113. " M.PARKING_US, \r\n"
  1114. " M.AR_LEVEL_SE, \r\n"
  1115. //" M.PRK_PLCE_IMAGE_DATA, \r\n"
  1116. " M.PRK_PLCE_IMAGE_TYPE, \r\n"
  1117. " M.PRK_PLCE_IMAGE_DC, \r\n"
  1118. " M.SYS_NE, \r\n"
  1119. " M.PARKING_CNTRL_SYS_INSTL_DE, \r\n"
  1120. " M.RELATION_LAW_AND_ORDINANCES, \r\n"
  1121. " M.PRK_AVAIL_CARTYPE, \r\n"
  1122. " M.PRK_CMPRT_CO, \r\n"
  1123. " M.COLCT_DEVICE_INSTL_AT, \r\n"
  1124. " M.MASTER_CONTROLLER, \r\n"
  1125. " M.SLAVE_CONTROLLER, \r\n"
  1126. " M.COLCT_DEVICE_QTY, \r\n"
  1127. " M.COLCT_DEVICE_KND, \r\n"
  1128. //" M.TYPE_IMGAGE, \r\n"
  1129. //" M.TYPE_GEOMAGNETIC, \r\n"
  1130. //" M.TYPE_RADAR, \r\n"
  1131. //" M.TYPE_LOOP, \r\n"
  1132. //" M.TYPE_ULTRASONIC, \r\n"
  1133. //" M.TYPE_ETC, \r\n"
  1134. " M.COLCT_DEVICE_INSTL_DE, \r\n"
  1135. " M.CRM_PRV_CCTV_INSTL_AT, \r\n"
  1136. " M.CRM_PRV_CCTV_INSTL_CO, \r\n"
  1137. " M.PIS_TYPE, \r\n"
  1138. " M.INFO_CREATE_TIME ) \r\n";
  1139. try
  1140. {
  1141. try
  1142. {
  1143. pADO = new TADOQuery(NULL);
  1144. pADO->Close();
  1145. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  1146. pADO->SQL->Clear();
  1147. pADO->SQL->Text = sQry;
  1148. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_NMBR;
  1149. pADO->Parameters->ParamByName("p02")->Value = AObj->CTLR_ID;
  1150. pADO->Parameters->ParamByName("p03")->Value = AObj->PRK_PLCE_STTUS_VER;
  1151. pADO->Parameters->ParamByName("p04")->Value = AObj->NAME;
  1152. pADO->Parameters->ParamByName("p44")->Value = AObj->VMS_DSPL_NM;
  1153. pADO->Parameters->ParamByName("p05")->Value = AObj->ISTL_LCTN_ADDR;
  1154. pADO->Parameters->ParamByName("p06")->Value = AObj->PRK_PLCE_INSTL_DE;
  1155. pADO->Parameters->ParamByName("p07")->Value = AObj->PRK_PLCE_ABL_DE;
  1156. pADO->Parameters->ParamByName("p08")->Value = AObj->PRK_PLCE_ENTRC_NM;
  1157. pADO->Parameters->ParamByName("p09")->Value = AObj->Y_CRDN;
  1158. pADO->Parameters->ParamByName("p10")->Value = AObj->X_CRDN;
  1159. pADO->Parameters->ParamByName("p11")->Value = AObj->PRK_PLCE_ENTRC_EXTTY;
  1160. pADO->Parameters->ParamByName("p12")->Value = AObj->PARKING_TY;
  1161. pADO->Parameters->ParamByName("p13")->Value = AObj->PARKING_US;
  1162. pADO->Parameters->ParamByName("p14")->Value = AObj->AR_LEVEL_SE;
  1163. //pADO->Parameters->ParamByName("p15")->Value = AObj->PRK_PLCE_IMAGE_DATA;
  1164. pADO->Parameters->ParamByName("p16")->Value = AObj->PRK_PLCE_IMAGE_TYPE;
  1165. pADO->Parameters->ParamByName("p17")->Value = AObj->PRK_PLCE_IMAGE_DC;
  1166. pADO->Parameters->ParamByName("p18")->Value = AObj->SYS_NE;
  1167. pADO->Parameters->ParamByName("p19")->Value = AObj->PARKING_CNTRL_SYS_INSTL_DE;
  1168. pADO->Parameters->ParamByName("p20")->Value = AObj->RELATION_LAW_AND_ORDINANCES;
  1169. pADO->Parameters->ParamByName("p21")->Value = AObj->PRK_AVAIL_CARTYPE;
  1170. pADO->Parameters->ParamByName("p22")->Value = AObj->PRK_CMPRT_CO;
  1171. pADO->Parameters->ParamByName("p23")->Value = AObj->COLCT_DEVICE_INSTL_AT;
  1172. pADO->Parameters->ParamByName("p24")->Value = AObj->MASTER_CONTROLLER;
  1173. pADO->Parameters->ParamByName("p25")->Value = AObj->SLAVE_CONTROLLER;
  1174. pADO->Parameters->ParamByName("p26")->Value = AObj->COLCT_DEVICE_QTY;
  1175. pADO->Parameters->ParamByName("p27")->Value = AObj->COLCT_DEVICE_KND;
  1176. //pADO->Parameters->ParamByName("p28")->Value = AObj->TYPE_IMGAGE;
  1177. //pADO->Parameters->ParamByName("p29")->Value = AObj->TYPE_GEOMAGNETIC;
  1178. //pADO->Parameters->ParamByName("p30")->Value = AObj->TYPE_RADAR;
  1179. //pADO->Parameters->ParamByName("p31")->Value = AObj->TYPE_LOOP;
  1180. //pADO->Parameters->ParamByName("p32")->Value = AObj->TYPE_ULTRASONIC;
  1181. //pADO->Parameters->ParamByName("p33")->Value = AObj->TYPE_ETC;
  1182. pADO->Parameters->ParamByName("p34")->Value = AObj->COLCT_DEVICE_INSTL_DE;
  1183. pADO->Parameters->ParamByName("p35")->Value = AObj->CRM_PRV_CCTV_INSTL_AT;
  1184. pADO->Parameters->ParamByName("p36")->Value = AObj->CRM_PRV_CCTV_INSTL_CO;
  1185. pADO->Parameters->ParamByName("p37")->Value = AObj->TYPE_CD;
  1186. pADO->Parameters->ParamByName("p38")->Value = AObj->INFO_CREATE_TIME;
  1187. pADO->ExecSQL();
  1188. MergePrkPlceOpr(AObj->FOPR, ADbConn);
  1189. MergeFcltInfo(AObj, ADbConn);
  1190. }
  1191. catch(EDatabaseError &E)
  1192. {
  1193. DBERRORMSG("TPrkPlceManager::MergePrkPlce", String(E.ClassName()), E.Message, sQry);
  1194. throw Exception(String(E.ClassName()) + E.Message);
  1195. }
  1196. catch(Exception &e)
  1197. {
  1198. DBERRORMSG("TPrkPlceManager::MergePrkPlce", String(e.ClassName()), e.Message, sQry);
  1199. throw Exception(String(e.ClassName()) + e.Message);
  1200. }
  1201. }
  1202. __finally
  1203. {
  1204. if (pADO)
  1205. {
  1206. pADO->Close();
  1207. delete pADO;
  1208. }
  1209. }
  1210. return true;
  1211. }
  1212. //---------------------------------------------------------------------------
  1213. bool TPrkPlceManager::MergePrkPlceOpr(TPrkPlceOpr *AObj, TADOConnection *ADbConn/*=NULL*/)
  1214. {
  1215. String sQry;
  1216. TADOQuery *pADO = NULL;
  1217. sQry = "MERGE INTO TB_PRK_PLCE_OPR L \r\n"
  1218. "USING (SELECT \r\n"
  1219. " :p01 AS PRK_PLCE_NMBR, \r\n"
  1220. " :p02 AS PRK_PLCE_OPR_VER, \r\n"
  1221. " :p03 AS CMPT_INST_NM, \r\n"
  1222. " :p04 AS OPER_DEPT_NM, \r\n"
  1223. " :p05 AS OPER_PERSON_NM, \r\n"
  1224. " :p06 AS OPER_CTT_PC_TEL, \r\n"
  1225. " :p07 AS OPER_CTT_PC_EMAIL, \r\n"
  1226. " :p08 AS NO_DRV_DAY_OPERTN_AT, \r\n"
  1227. " :p09 AS OPERTN_BS_FREE_TIME, \r\n"
  1228. " :p10 AS OPN_CODE, \r\n"
  1229. " :p11 AS PARKING_CHRGE_EXCCLC_MTHD, \r\n"
  1230. " :p12 AS PARKING_CHRGE_PYMNT_MN, \r\n"
  1231. " :p13 AS PARKING_RESVE_OPERTN_AT, \r\n"
  1232. " :p14 AS PARTCLR_MATTER, \r\n"
  1233. " :p15 AS INFO_CREATE_TIME \r\n"
  1234. " FROM DUAL) M \r\n"
  1235. " ON (L.PRK_PLCE_NMBR = M.PRK_PLCE_NMBR) \r\n"
  1236. "WHEN MATCHED THEN \r\n"
  1237. " UPDATE SET \r\n"
  1238. " L.PRK_PLCE_OPR_VER = M.PRK_PLCE_OPR_VER, \r\n"
  1239. " L.CMPT_INST_NM = M.CMPT_INST_NM, \r\n"
  1240. " L.OPER_DEPT_NM = M.OPER_DEPT_NM, \r\n"
  1241. " L.OPER_PERSON_NM = M.OPER_PERSON_NM, \r\n"
  1242. " L.OPER_CTT_PC_TEL = M.OPER_CTT_PC_TEL, \r\n"
  1243. " L.OPER_CTT_PC_EMAIL = M.OPER_CTT_PC_EMAIL, \r\n"
  1244. " L.NO_DRV_DAY_OPERTN_AT = M.NO_DRV_DAY_OPERTN_AT, \r\n"
  1245. " L.OPERTN_BS_FREE_TIME = M.OPERTN_BS_FREE_TIME, \r\n"
  1246. " L.OPN_CODE = M.OPN_CODE, \r\n"
  1247. " L.PARKING_CHRGE_EXCCLC_MTHD = M.PARKING_CHRGE_EXCCLC_MTHD, \r\n"
  1248. " L.PARKING_CHRGE_PYMNT_MN = M.PARKING_CHRGE_PYMNT_MN, \r\n"
  1249. " L.PARKING_RESVE_OPERTN_AT = M.PARKING_RESVE_OPERTN_AT, \r\n"
  1250. " L.PARTCLR_MATTER = M.PARTCLR_MATTER, \r\n"
  1251. " L.INFO_CREATE_TIME = M.INFO_CREATE_TIME \r\n"
  1252. "WHEN NOT MATCHED THEN \r\n"
  1253. " INSERT ( \r\n"
  1254. " PRK_PLCE_NMBR, \r\n"
  1255. " PRK_PLCE_OPR_VER, \r\n"
  1256. " CMPT_INST_NM, \r\n"
  1257. " OPER_DEPT_NM, \r\n"
  1258. " OPER_PERSON_NM, \r\n"
  1259. " OPER_CTT_PC_TEL, \r\n"
  1260. " OPER_CTT_PC_EMAIL, \r\n"
  1261. " NO_DRV_DAY_OPERTN_AT, \r\n"
  1262. " OPERTN_BS_FREE_TIME, \r\n"
  1263. " OPN_CODE, \r\n"
  1264. " PARKING_CHRGE_EXCCLC_MTHD, \r\n"
  1265. " PARKING_CHRGE_PYMNT_MN, \r\n"
  1266. " PARKING_RESVE_OPERTN_AT, \r\n"
  1267. " PARTCLR_MATTER, \r\n"
  1268. " INFO_CREATE_TIME ) \r\n"
  1269. " VALUES ( \r\n"
  1270. " M.PRK_PLCE_NMBR, \r\n"
  1271. " M.PRK_PLCE_OPR_VER, \r\n"
  1272. " M.CMPT_INST_NM, \r\n"
  1273. " M.OPER_DEPT_NM, \r\n"
  1274. " M.OPER_PERSON_NM, \r\n"
  1275. " M.OPER_CTT_PC_TEL, \r\n"
  1276. " M.OPER_CTT_PC_EMAIL, \r\n"
  1277. " M.NO_DRV_DAY_OPERTN_AT, \r\n"
  1278. " M.OPERTN_BS_FREE_TIME, \r\n"
  1279. " M.OPN_CODE, \r\n"
  1280. " M.PARKING_CHRGE_EXCCLC_MTHD, \r\n"
  1281. " M.PARKING_CHRGE_PYMNT_MN, \r\n"
  1282. " M.PARKING_RESVE_OPERTN_AT, \r\n"
  1283. " M.PARTCLR_MATTER, \r\n"
  1284. " M.INFO_CREATE_TIME ) \r\n";
  1285. try
  1286. {
  1287. try
  1288. {
  1289. pADO = new TADOQuery(NULL);
  1290. pADO->Close();
  1291. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  1292. pADO->SQL->Clear();
  1293. pADO->SQL->Text = sQry;
  1294. pADO->Parameters->ParamByName("p01")->Value = AObj->PRK_PLCE_NMBR;
  1295. pADO->Parameters->ParamByName("p02")->Value = AObj->PRK_PLCE_OPR_VER;
  1296. pADO->Parameters->ParamByName("p03")->Value = AObj->CMPT_INST_NM;
  1297. pADO->Parameters->ParamByName("p04")->Value = AObj->OPER_DEPT_NM;
  1298. pADO->Parameters->ParamByName("p05")->Value = AObj->OPER_PERSON_NM;
  1299. pADO->Parameters->ParamByName("p06")->Value = AObj->OPER_CTT_PC_TEL;
  1300. pADO->Parameters->ParamByName("p07")->Value = AObj->OPER_CTT_PC_EMAIL;
  1301. pADO->Parameters->ParamByName("p08")->Value = AObj->NO_DRV_DAY_OPERTN_AT;
  1302. pADO->Parameters->ParamByName("p09")->Value = AObj->OPERTN_BS_FREE_TIME;
  1303. pADO->Parameters->ParamByName("p10")->Value = AObj->OPN_CODE;
  1304. pADO->Parameters->ParamByName("p11")->Value = AObj->PARKING_CHRGE_EXCCLC_MTHD;
  1305. pADO->Parameters->ParamByName("p12")->Value = AObj->PARKING_CHRGE_PYMNT_MN;
  1306. pADO->Parameters->ParamByName("p13")->Value = AObj->PARKING_RESVE_OPERTN_AT;
  1307. pADO->Parameters->ParamByName("p14")->Value = AObj->PARTCLR_MATTER;
  1308. pADO->Parameters->ParamByName("p15")->Value = AObj->INFO_CREATE_TIME;
  1309. pADO->ExecSQL();
  1310. }
  1311. catch(EDatabaseError &E)
  1312. {
  1313. DBERRORMSG("TPrkPlceManager::MergePrkPlceOpr", String(E.ClassName()), E.Message, sQry);
  1314. throw Exception(String(E.ClassName()) + E.Message);
  1315. }
  1316. catch(Exception &e)
  1317. {
  1318. DBERRORMSG("TPrkPlceManager::MergePrkPlceOpr", String(e.ClassName()), e.Message, sQry);
  1319. throw Exception(String(e.ClassName()) + e.Message);
  1320. }
  1321. }
  1322. __finally
  1323. {
  1324. if (pADO)
  1325. {
  1326. pADO->Close();
  1327. delete pADO;
  1328. }
  1329. }
  1330. return true;
  1331. }
  1332. //---------------------------------------------------------------------------
  1333. bool TPrkPlceManager::MergePrkPlcePrv(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  1334. {
  1335. String sQry;
  1336. TADOQuery *pADO = NULL;
  1337. #if 0
  1338. sQry = "MERGE INTO TB_PRK_PLCE_PRV L \r\n"
  1339. "USING (SELECT \r\n"
  1340. " :p01 AS PRK_PLCE_NMBR, \r\n"
  1341. " :p02 AS VHCTY_AR_SE, \r\n"
  1342. " :p03 AS VHCTY_AR_PRK_CMPRT_CO, \r\n"
  1343. " 0 AS VHCTY_AR_REMNDR_PRK_CMPRT_CO \r\n"
  1344. " FROM DUAL) M \r\n"
  1345. " ON (L.PRK_PLCE_NMBR = M.PRK_PLCE_NMBR) \r\n"
  1346. "WHEN MATCHED THEN \r\n"
  1347. " UPDATE SET \r\n"
  1348. " L.VHCTY_AR_SE = M.VHCTY_AR_SE, \r\n"
  1349. " L.VHCTY_AR_PRK_CMPRT_CO = M.VHCTY_AR_PRK_CMPRT_CO \r\n"
  1350. "WHEN NOT MATCHED THEN \r\n"
  1351. " INSERT ( \r\n"
  1352. " PRK_PLCE_NMBR, \r\n"
  1353. " VHCTY_AR_SE, \r\n"
  1354. " VHCTY_AR_PRK_CMPRT_CO, \r\n"
  1355. " VHCTY_AR_REMNDR_PRK_CMPRT_CO ) \r\n"
  1356. " VALUES ( \r\n"
  1357. " M.PRK_PLCE_NMBR, \r\n"
  1358. " M.VHCTY_AR_SE, \r\n"
  1359. " M.VHCTY_AR_PRK_CMPRT_CO, \r\n"
  1360. " M.VHCTY_AR_REMNDR_PRK_CMPRT_CO ) \r\n";
  1361. try
  1362. {
  1363. try
  1364. {
  1365. pADO = new TADOQuery(NULL);
  1366. pADO->Close();
  1367. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  1368. pADO->SQL->Clear();
  1369. pADO->SQL->Text = sQry;
  1370. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_ID;
  1371. pADO->Parameters->ParamByName("p02")->Value = "PARK";
  1372. pADO->Parameters->ParamByName("p03")->Value = AObj->NAME;
  1373. pADO->ExecSQL();
  1374. return true;
  1375. }
  1376. catch(EDatabaseError &E)
  1377. {
  1378. DBERRORMSG("TPrkPlceManager::MergeFcltInfo", String(E.ClassName()), E.Message, sQry);
  1379. throw Exception(String(E.ClassName()) + E.Message);
  1380. }
  1381. catch(Exception &e)
  1382. {
  1383. DBERRORMSG("TPrkPlceManager::MergeFcltInfo", String(e.ClassName()), e.Message, sQry);
  1384. throw Exception(String(e.ClassName()) + e.Message);
  1385. }
  1386. }
  1387. __finally
  1388. {
  1389. if (pADO)
  1390. {
  1391. pADO->Close();
  1392. delete pADO;
  1393. }
  1394. }
  1395. #endif
  1396. return true;
  1397. }
  1398. //---------------------------------------------------------------------------
  1399. bool TPrkPlceManager::MergeFcltInfo(TPrkPlce *AObj, TADOConnection *ADbConn/*=NULL*/)
  1400. {
  1401. String sQry;
  1402. TADOQuery *pADO = NULL;
  1403. sQry = "MERGE INTO TB_FCLT_INFR L \r\n"
  1404. "USING (SELECT :p01 AS FCLT_ID, \r\n"
  1405. " :p02 AS FCLT_TYPE, \r\n"
  1406. " :p03 AS FCLT_LCTN \r\n"
  1407. " FROM DUAL) M \r\n"
  1408. " ON (L.FCLT_ID = M.FCLT_ID AND L.FCLT_TYPE = M.FCLT_TYPE) \r\n"
  1409. "WHEN MATCHED \r\n"
  1410. "THEN \r\n"
  1411. " UPDATE SET L.FCLT_LCTN = M.FCLT_LCTN, \r\n"
  1412. " L.DEL_YN = 'N' \r\n"
  1413. "WHEN NOT MATCHED \r\n"
  1414. "THEN \r\n"
  1415. " INSERT ( FCLT_ID, FCLT_TYPE, FCLT_LCTN) \r\n"
  1416. " VALUES (M.FCLT_ID, M.FCLT_TYPE, M.FCLT_LCTN) \r\n";
  1417. try
  1418. {
  1419. try
  1420. {
  1421. pADO = new TADOQuery(NULL);
  1422. pADO->Close();
  1423. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  1424. pADO->SQL->Clear();
  1425. pADO->SQL->Text = sQry;
  1426. pADO->Parameters->ParamByName("p01")->Value = AObj->CTLR_ID;
  1427. pADO->Parameters->ParamByName("p02")->Value = "PARK";
  1428. pADO->Parameters->ParamByName("p03")->Value = AObj->NAME;
  1429. pADO->ExecSQL();
  1430. return true;
  1431. }
  1432. catch(EDatabaseError &E)
  1433. {
  1434. DBERRORMSG("TPrkPlceManager::MergeFcltInfo", String(E.ClassName()), E.Message, sQry);
  1435. throw Exception(String(E.ClassName()) + E.Message);
  1436. }
  1437. catch(Exception &e)
  1438. {
  1439. DBERRORMSG("TPrkPlceManager::MergeFcltInfo", String(e.ClassName()), e.Message, sQry);
  1440. throw Exception(String(e.ClassName()) + e.Message);
  1441. }
  1442. }
  1443. __finally
  1444. {
  1445. if (pADO)
  1446. {
  1447. pADO->Close();
  1448. delete pADO;
  1449. }
  1450. }
  1451. return true;
  1452. }
  1453. //---------------------------------------------------------------------------