CDSDsrcSectF.cpp 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452
  1. //---------------------------------------------------------------------------
  2. #pragma hdrstop
  3. #include "CDSDsrcSectF.h"
  4. #include "ITSDbF.h"
  5. #include "AppGlobalF.h"
  6. //---------------------------------------------------------------------------
  7. #pragma package(smart_init)
  8. TItsDsrcSectLink::TItsDsrcSectLink()
  9. {
  10. FCompleted = false;
  11. FEditMode = DB_INIT;
  12. FGridIndex = -1;
  13. MEM_DEL = "N";
  14. //Clear();
  15. }
  16. //---------------------------------------------------------------------------
  17. void TItsDsrcSectLink::Clear()
  18. {
  19. RSE_SECT_ID = "";
  20. LINK_ID = "";
  21. LINK_ORD = "";
  22. }
  23. //---------------------------------------------------------------------------
  24. TItsDsrcSectLink::~TItsDsrcSectLink()
  25. {
  26. }
  27. //---------------------------------------------------------------------------
  28. TItsDsrcSect::TItsDsrcSect()
  29. {
  30. FCompleted = false;
  31. FEditMode = DB_INIT;
  32. FGridIndex = -1;
  33. MEM_DEL = "N";
  34. //Clear();
  35. }
  36. //---------------------------------------------------------------------------
  37. void TItsDsrcSect::Clear()
  38. {
  39. String RSE_SECT_ID = "";
  40. String DSTC = "";
  41. String RSE_SECT_NM = "";
  42. String STRT_SPOT_NM = "";
  43. String END_SPOT_NM = "";
  44. String DEL_YN = "";
  45. String STRT_ID = "";
  46. String END_ID = "";
  47. }
  48. //---------------------------------------------------------------------------
  49. TItsDsrcSect::~TItsDsrcSect()
  50. {
  51. }
  52. //---------------------------------------------------------------------------
  53. //---------------------------------------------------------------------------
  54. TItsDsrcSectManager *ItsDsrcSectManager = NULL;
  55. //---------------------------------------------------------------------------
  56. /*
  57. * DsrcSect Manager
  58. */
  59. TItsDsrcSectManager::TItsDsrcSectManager()
  60. {
  61. }
  62. //---------------------------------------------------------------------------
  63. TItsDsrcSectManager::~TItsDsrcSectManager()
  64. {
  65. FLists.RemoveAll();
  66. }
  67. //---------------------------------------------------------------------------
  68. bool TItsDsrcSectManager::LoadFromDb(TADOConnection *ADbConn/*=NULL*/)
  69. {
  70. FLists.RemoveAll();
  71. LoadSectMstr(ADbConn);
  72. LoadSectLink(ADbConn);
  73. return true;
  74. }
  75. //---------------------------------------------------------------------------
  76. bool TItsDsrcSectManager::LoadSectLink(TADOConnection *ADbConn/*=NULL*/)
  77. {
  78. String sQry;
  79. TADOQuery *pADO = NULL;
  80. sQry = "SELECT RSE_SECT_ID, \r\n"
  81. " LINK_ID, \r\n"
  82. " LINK_ORD \r\n"
  83. " FROM TB_RSE_SECT_LINK \r\n";
  84. try
  85. {
  86. FLists.Lock();
  87. try
  88. {
  89. pADO = new TADOQuery(NULL);
  90. pADO->Close();
  91. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  92. pADO->SQL->Clear();
  93. pADO->SQL->Text = sQry;
  94. pADO->Open();
  95. for( ; !pADO->Eof; pADO->Next())
  96. {
  97. String sRseSectId = pADO->FieldByName("RSE_SECT_ID")->AsString;
  98. TItsDsrcSect *pObj = FLists.Find(sRseSectId);
  99. if (!pObj) continue;
  100. TItsDsrcSectLink *pLinkObj = new TItsDsrcSectLink();
  101. pLinkObj->RSE_SECT_ID = pADO->FieldByName("RSE_SECT_ID")->AsString;
  102. pLinkObj->LINK_ID = pADO->FieldByName("LINK_ID")->AsString;
  103. pLinkObj->LINK_ORD = pADO->FieldByName("LINK_ORD")->AsString;
  104. pLinkObj->DEL_YN = "N";
  105. pObj->FLinkLists.Push(pLinkObj->LINK_ORD, pLinkObj);
  106. pLinkObj->Completed = true;
  107. pLinkObj->MEM_DEL = "N";
  108. }
  109. }
  110. catch(EDatabaseError &E)
  111. {
  112. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  113. DBERRORMSG("RSE구간링크정보조회", String(E.ClassName()), E.Message, sQry);
  114. throw Exception(String(E.ClassName()) + E.Message);
  115. }
  116. catch(Exception &exception)
  117. {
  118. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  119. DBERRORMSG("RSE구간링크정보조회", String(exception.ClassName()), exception.Message, sQry);
  120. throw Exception(String(exception.ClassName()) + exception.Message);
  121. }
  122. }
  123. __finally
  124. {
  125. if (pADO)
  126. {
  127. pADO->Close();
  128. delete pADO;
  129. }
  130. FLists.UnLock();
  131. }
  132. return true;
  133. }
  134. //---------------------------------------------------------------------------
  135. bool TItsDsrcSectManager::LoadSectMstr(TADOConnection *ADbConn/*=NULL*/)
  136. {
  137. String sQry;
  138. TADOQuery *pADO = NULL;
  139. sQry = "SELECT RSE_SECT_ID , \r\n"
  140. " DSTC , \r\n"
  141. " RSE_SECT_NM , \r\n"
  142. " STRT_SPOT_NM, \r\n"
  143. " END_SPOT_NM , \r\n"
  144. " DEL_YN , \r\n"
  145. " STRT_ID , \r\n"
  146. " END_ID \r\n"
  147. " FROM TB_RSE_SECT_MSTR \r\n";
  148. //" WHERE DEL_YN = 'N' \r\n";
  149. //" ORDER BY TO_NUMBER(RSE_SECT_ID) \r\n";
  150. try
  151. {
  152. FLists.Lock();
  153. FLists.RemoveAll();
  154. try
  155. {
  156. pADO = new TADOQuery(NULL);
  157. pADO->Close();
  158. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  159. pADO->SQL->Clear();
  160. pADO->SQL->Text = sQry;
  161. pADO->Open();
  162. for( ; !pADO->Eof; pADO->Next())
  163. {
  164. TItsDsrcSect *pObj = new TItsDsrcSect();
  165. pObj->RSE_SECT_ID = pADO->FieldByName("RSE_SECT_ID")->AsString;
  166. pObj->DSTC = pADO->FieldByName("DSTC")->AsString;
  167. pObj->RSE_SECT_NM = pADO->FieldByName("RSE_SECT_NM")->AsString;
  168. pObj->STRT_SPOT_NM = pADO->FieldByName("STRT_SPOT_NM")->AsString;
  169. pObj->END_SPOT_NM = pADO->FieldByName("END_SPOT_NM")->AsString;
  170. pObj->DEL_YN = pADO->FieldByName("DEL_YN")->AsString;
  171. pObj->STRT_ID = pADO->FieldByName("STRT_ID")->AsString;
  172. pObj->END_ID = pADO->FieldByName("END_ID")->AsString;
  173. FLists.Push(pObj->RSE_SECT_ID, pObj);
  174. pObj->Completed = true;
  175. pObj->MEM_DEL = "N";
  176. }
  177. }
  178. catch(EDatabaseError &E)
  179. {
  180. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  181. DBERRORMSG("RSE구간정보조회", String(E.ClassName()), E.Message, sQry);
  182. throw Exception(String(E.ClassName()) + E.Message);
  183. }
  184. catch(Exception &exception)
  185. {
  186. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  187. DBERRORMSG("RSE구간정보조회", String(exception.ClassName()), exception.Message, sQry);
  188. throw Exception(String(exception.ClassName()) + exception.Message);
  189. }
  190. }
  191. __finally
  192. {
  193. if (pADO)
  194. {
  195. pADO->Close();
  196. delete pADO;
  197. }
  198. FLists.UnLock();
  199. }
  200. return true;
  201. }
  202. //---------------------------------------------------------------------------
  203. bool TItsDsrcSectManager::GetNextSectId(String &ANewId, TADOConnection *ADbConn/*=NULL*/)
  204. {
  205. String sQry;
  206. TADOQuery *pADO = NULL;
  207. sQry = "SELECT TO_NUMBER(CASE WHEN EXISTS (SELECT 1 FROM TB_RSE_SECT_MSTR) \r\n"
  208. " THEN (SELECT TRIM(MAX(TO_NUMBER(RSE_SECT_ID)) + 1) \r\n"
  209. " FROM TB_RSE_SECT_MSTR) \r\n"
  210. " ELSE '1' END) AS NEWID \r\n"
  211. " FROM DUAL \r\n";
  212. ANewId = "";
  213. try
  214. {
  215. try
  216. {
  217. pADO = new TADOQuery(NULL);
  218. pADO->Close();
  219. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  220. pADO->SQL->Clear();
  221. pADO->SQL->Text = sQry;
  222. pADO->Open();
  223. ANewId = pADO->FieldByName("NEWID")->AsString;
  224. return true;
  225. }
  226. catch(EDatabaseError &E)
  227. {
  228. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  229. DBERRORMSG("RSE 신규구간ID조회", String(E.ClassName()), E.Message, sQry);
  230. throw Exception(String(E.ClassName()) + E.Message);
  231. }
  232. catch(Exception &exception)
  233. {
  234. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  235. DBERRORMSG("RSE 신규구간ID조회", String(exception.ClassName()), exception.Message, sQry);
  236. throw Exception(String(exception.ClassName()) + exception.Message);
  237. }
  238. }
  239. __finally
  240. {
  241. if (pADO)
  242. {
  243. pADO->Close();
  244. delete pADO;
  245. }
  246. }
  247. return false;
  248. }
  249. //---------------------------------------------------------------------------
  250. bool TItsDsrcSectManager::DeleteSect(String ASectId, TADOConnection *ADbConn/*=NULL*/)
  251. {
  252. String sQry;
  253. TADOQuery *pADO = NULL;
  254. //수집구간목록
  255. sQry = "DELETE TB_RSE_SECT_LINK WHERE RSE_SECT_ID = :p01 \r\n";
  256. try
  257. {
  258. FLists.Lock();
  259. try
  260. {
  261. pADO = new TADOQuery(NULL);
  262. pADO->Close();
  263. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  264. pADO->SQL->Clear();
  265. pADO->SQL->Text = sQry;
  266. pADO->Parameters->ParamByName("p01")->Value = ASectId;
  267. pADO->ExecSQL();
  268. #if 0
  269. //정보제공이력-->외래키를 삭제하는것이 맞음
  270. sQry = "DELETE TB_RSE_OFFR_INFR_HS WHERE OFFR_SECT_ID = :p01 \r\n";
  271. pADO->SQL->Clear();
  272. pADO->SQL->Text = sQry;
  273. pADO->Parameters->ParamByName("p01")->Value = AOfferSectId;
  274. pADO->ExecSQL();
  275. #endif
  276. //수집구간 마스터
  277. //sQry = "DELETE TB_RSE_SECT_MSTR WHERE RSE_SECT_ID = :p01 \r\n";
  278. sQry = "UPDATE TB_RSE_SECT_MSTR SET DEL_YN = 'Y' WHERE RSE_SECT_ID = :p01 \r\n";
  279. pADO->SQL->Clear();
  280. pADO->SQL->Text = sQry;
  281. pADO->Parameters->ParamByName("p01")->Value = ASectId;
  282. pADO->ExecSQL();
  283. return true;
  284. }
  285. catch(EDatabaseError &E)
  286. {
  287. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  288. DBERRORMSG("RSE구간정보삭제", String(E.ClassName()), E.Message, sQry);
  289. throw Exception(String(E.ClassName()) + E.Message);
  290. }
  291. catch(Exception &exception)
  292. {
  293. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  294. DBERRORMSG("RSE구간정보삭제", String(exception.ClassName()), exception.Message, sQry);
  295. throw Exception(String(exception.ClassName()) + exception.Message);
  296. }
  297. }
  298. __finally
  299. {
  300. if (pADO)
  301. {
  302. pADO->Close();
  303. delete pADO;
  304. }
  305. FLists.UnLock();
  306. }
  307. return true;
  308. }
  309. //---------------------------------------------------------------------------
  310. bool TItsDsrcSectManager::SaveSect(TItsDsrcSect *AObj, TADOConnection *ADbConn/*=NULL*/)
  311. {
  312. String sQry;
  313. TADOQuery *pADO = NULL;
  314. //수집구간 링크구성정보 삭제
  315. sQry = "DELETE FROM TB_RSE_SECT_LINK WHERE RSE_SECT_ID = :p01 \r\n";
  316. try
  317. {
  318. FLists.Lock();
  319. try
  320. {
  321. pADO = new TADOQuery(NULL);
  322. pADO->Close();
  323. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  324. pADO->SQL->Clear();
  325. pADO->SQL->Text = sQry;
  326. pADO->Parameters->ParamByName("p01")->Value = AObj->RSE_SECT_ID;
  327. pADO->ExecSQL();
  328. //수집구간 마스터
  329. sQry = "MERGE INTO TB_RSE_SECT_MSTR L \r\n"
  330. "USING (SELECT :p01 AS RSE_SECT_ID, \r\n"
  331. " :p02 AS DSTC, \r\n"
  332. " :p03 AS RSE_SECT_NM, \r\n"
  333. " :p04 AS STRT_SPOT_NM, \r\n"
  334. " :p05 AS END_SPOT_NM, \r\n"
  335. " :p06 AS DEL_YN, \r\n"
  336. " :p07 AS STRT_ID, \r\n"
  337. " :p08 AS END_ID \r\n"
  338. " FROM DUAL) M \r\n"
  339. " ON (L.RSE_SECT_ID = M.RSE_SECT_ID) \r\n"
  340. "WHEN MATCHED THEN \r\n"
  341. " UPDATE SET DSTC = M.DSTC, \r\n"
  342. " RSE_SECT_NM = M.RSE_SECT_NM, \r\n"
  343. " STRT_SPOT_NM = M.STRT_SPOT_NM, \r\n"
  344. " END_SPOT_NM = M.END_SPOT_NM, \r\n"
  345. " DEL_YN = M.DEL_YN, \r\n"
  346. " STRT_ID = M.STRT_ID, \r\n"
  347. " END_ID = M.END_ID \r\n"
  348. "WHEN NOT MATCHED THEN \r\n"
  349. "INSERT ( RSE_SECT_ID, DSTC, RSE_SECT_NM, \r\n"
  350. " STRT_SPOT_NM, END_SPOT_NM, \r\n"
  351. " DEL_YN, STRT_ID, END_ID) \r\n"
  352. "VALUES (M.RSE_SECT_ID, M.DSTC, M.RSE_SECT_NM, \r\n"
  353. " M.STRT_SPOT_NM, M.END_SPOT_NM, \r\n"
  354. " M.DEL_YN, M.STRT_ID, M.END_ID) \r\n";
  355. pADO->SQL->Clear();
  356. pADO->SQL->Text = sQry;
  357. pADO->Parameters->ParamByName("p01")->Value = AObj->RSE_SECT_ID;
  358. pADO->Parameters->ParamByName("p02")->Value = AObj->DSTC;
  359. pADO->Parameters->ParamByName("p03")->Value = AObj->RSE_SECT_NM;
  360. pADO->Parameters->ParamByName("p04")->Value = AObj->STRT_SPOT_NM;
  361. pADO->Parameters->ParamByName("p05")->Value = AObj->END_SPOT_NM;
  362. pADO->Parameters->ParamByName("p06")->Value = AObj->DEL_YN;
  363. pADO->Parameters->ParamByName("p07")->Value = AObj->STRT_ID;
  364. pADO->Parameters->ParamByName("p08")->Value = AObj->END_ID;
  365. pADO->ExecSQL();
  366. //정보제공구간 링크구성정보 입력
  367. sQry = "INSERT INTO TB_RSE_SECT_LINK (RSE_SECT_ID, LINK_ID, LINK_ORD) \r\n"
  368. " VALUES (:p01, :p02, :p03) \r\n";
  369. int nOrd = 1;
  370. pADO->SQL->Clear();
  371. pADO->SQL->Text = sQry;
  372. FOR_STL(TItsDsrcSectLink *, pObj, AObj->FLinkLists)
  373. {
  374. pADO->Parameters->ParamByName("p01")->Value = AObj->RSE_SECT_ID;
  375. pADO->Parameters->ParamByName("p02")->Value = pObj->LINK_ID;
  376. pADO->Parameters->ParamByName("p03")->Value = nOrd;
  377. pADO->ExecSQL();
  378. nOrd++;
  379. }
  380. return true;
  381. }
  382. catch(EDatabaseError &E)
  383. {
  384. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  385. DBERRORMSG("RSE구간정보업데이트", String(E.ClassName()), E.Message, sQry);
  386. throw Exception(String(E.ClassName()) + E.Message);
  387. }
  388. catch(Exception &exception)
  389. {
  390. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  391. DBERRORMSG("RSE구간정보업데이트", String(exception.ClassName()), exception.Message, sQry);
  392. throw Exception(String(exception.ClassName()) + exception.Message);
  393. }
  394. }
  395. __finally
  396. {
  397. if (pADO)
  398. {
  399. pADO->Close();
  400. delete pADO;
  401. }
  402. FLists.UnLock();
  403. }
  404. return true;
  405. }
  406. //---------------------------------------------------------------------------