CDSDsrcSectF.cpp 15 KB

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