CDSAviF.cpp 45 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153
  1. //---------------------------------------------------------------------------
  2. #pragma hdrstop
  3. #include "CDSAviF.h"
  4. #include "ITSDbF.h"
  5. #include "AppGlobalF.h"
  6. //---------------------------------------------------------------------------
  7. #pragma package(smart_init)
  8. TItsAviDtct::TItsAviDtct()
  9. {
  10. DTCT_NMBR = "";
  11. DTCT_NM = "";
  12. CTLR_MNGM_NMBR = "";
  13. DTCT_TYPE_CD = "";
  14. ISTL_LANE = "";
  15. USE_YN = "";
  16. DEL_YN = "";
  17. MAX_TFVL = 0;
  18. MIN_TFVL = 0;
  19. MAX_OCPY_RATE = 0;
  20. MIN_OCPY_RATE = 0;
  21. MIN_SPED = 0;
  22. MAX_SPED = 0;
  23. MEM_DEL = "";
  24. }
  25. //---------------------------------------------------------------------------
  26. TItsAviDtct::~TItsAviDtct()
  27. {
  28. }
  29. //---------------------------------------------------------------------------
  30. TItsAvi::TItsAvi()
  31. {
  32. FCompleted = false;
  33. FEditMode = DB_INIT;
  34. FGridIndex = -1;
  35. MEM_DEL = "N";
  36. //Clear();
  37. }
  38. //---------------------------------------------------------------------------
  39. void TItsAvi::Clear()
  40. {
  41. AVI_CTLR_MNGM_NMBR = "";
  42. AVI_ID = "";
  43. LINK_ID = "";
  44. AVI_LCTN_NM = "";
  45. AVI_VALD_YN = "";
  46. AVI_CTLR_IP = "";
  47. AVI_CTLR_CMNC_PORT = "";
  48. AVI_MAIN_CTLR_YN = "";
  49. AVI_MNGM_LANE_NUM = "";
  50. AVI_CMRA_NUM = "";
  51. AVI_DTCT_NUM = "";
  52. AVI_DTCT_NM = "";
  53. AVI_CLCT_CYCL = "";
  54. AVI_LAMP_AUTO_YN = "";
  55. AVI_LAMP_ON_HMS = "";
  56. AVI_LAMP_OFF_HMS = "";
  57. AVI_LAMP_ON_YN = "";
  58. X_CRDN = "";
  59. Y_CRDN = "";
  60. RMRK = "";
  61. DEL_YN = "";
  62. FRST_REGR_NMBR = "";
  63. FRST_RGST_DT = "";
  64. LAST_CRPR_NMBR = "";
  65. LAST_CRCT_DT = "";
  66. MEM_DEL = "";
  67. }
  68. //---------------------------------------------------------------------------
  69. TItsAvi::~TItsAvi()
  70. {
  71. }
  72. //---------------------------------------------------------------------------
  73. TItsAviSect::TItsAviSect()
  74. {
  75. FCompleted = false;
  76. FEditMode = DB_INIT;
  77. FGridIndex = -1;
  78. MEM_DEL = "N";
  79. //Clear();
  80. }
  81. //---------------------------------------------------------------------------
  82. void TItsAviSect::Clear()
  83. {
  84. AVI_CTLR_MNGM_NMBR = "";
  85. ORD = 0;
  86. AVI_SECT_NMBR = "";
  87. STRT_SPOT_NM = "";
  88. END_SPOT_NM = "";
  89. AVI_SECT_NM = "";
  90. AVI_SECT_DSTC = "";
  91. SHRT_PASS_HH = "";
  92. LNST_PASS_HH = "";
  93. SPOT_NUM = "";
  94. STND_DRFT_VAL = "";
  95. MIN_SPED = "";
  96. MAX_SPED = "";
  97. SMTH_FCTR = "";
  98. DEL_YN = "";
  99. FRST_REGR_NMBR = "";
  100. FRST_RGST_DT = "";
  101. LAST_CRPR_NMBR = "";
  102. LAST_CRCT_DT = "";
  103. MEM_DEL = "";
  104. }
  105. //---------------------------------------------------------------------------
  106. TItsAviSect::~TItsAviSect()
  107. {
  108. }
  109. //---------------------------------------------------------------------------
  110. TItsAviLink::TItsAviLink()
  111. {
  112. FCompleted = false;
  113. FEditMode = DB_INIT;
  114. FGridIndex = -1;
  115. MEM_DEL = "N";
  116. //Clear();
  117. }
  118. //---------------------------------------------------------------------------
  119. void TItsAviLink::Clear()
  120. {
  121. AVI_CTLR_MNGM_NMBR = "";
  122. AVI_SECT_NMBR = "";
  123. LINK_ID = "";
  124. ORD = 0;
  125. MEM_DEL = "";
  126. }
  127. //---------------------------------------------------------------------------
  128. TItsAviLink::~TItsAviLink()
  129. {
  130. }
  131. //---------------------------------------------------------------------------
  132. //---------------------------------------------------------------------------
  133. TItsAviManager *ItsAviManager = NULL;
  134. //---------------------------------------------------------------------------
  135. /*
  136. * Avi Manager
  137. */
  138. TItsAviManager::TItsAviManager()
  139. {
  140. }
  141. //---------------------------------------------------------------------------
  142. TItsAviManager::~TItsAviManager()
  143. {
  144. FLists.RemoveAll();
  145. FSectLists.RemoveAll();
  146. }
  147. //---------------------------------------------------------------------------
  148. bool TItsAviManager::LoadFromDb(TADOConnection *ADbConn/*=NULL*/)
  149. {
  150. String sQry;
  151. TADOQuery *pADO = NULL;
  152. sQry = "SELECT AVI_CTLR_MNGM_NMBR, \r\n"
  153. " AVI_ID, \r\n"
  154. " LINK_ID, \r\n"
  155. " AVI_LCTN_NM, \r\n"
  156. " AVI_VALD_YN, \r\n"
  157. " AVI_CTLR_IP, \r\n"
  158. " AVI_CTLR_CMNC_PORT, \r\n"
  159. " AVI_MAIN_CTLR_YN, \r\n"
  160. " AVI_MNGM_LANE_NUM, \r\n"
  161. " AVI_CMRA_NUM, \r\n"
  162. " AVI_DTCT_NUM, \r\n"
  163. " AVI_DTCT_NM, \r\n"
  164. " AVI_CLCT_CYCL, \r\n"
  165. " AVI_LAMP_AUTO_YN, \r\n"
  166. " AVI_LAMP_ON_HMS, \r\n"
  167. " AVI_LAMP_OFF_HMS, \r\n"
  168. " AVI_LAMP_ON_YN, \r\n"
  169. " X_CRDN, \r\n"
  170. " Y_CRDN, \r\n"
  171. " RMRK, \r\n"
  172. " DEL_YN, \r\n"
  173. " FRST_REGR_NMBR, \r\n"
  174. " FRST_RGST_DT, \r\n"
  175. " LAST_CRPR_NMBR, \r\n"
  176. " LAST_CRCT_DT \r\n"
  177. " FROM TB_AVI_CTLR \r\n";
  178. //" WHERE DEL_YN = 'N' \r\n";
  179. //" ORDER BY AVI_CTLR_MNGM_NMBR \r\n";
  180. try
  181. {
  182. FLists.Lock();
  183. FLists.RemoveAll();
  184. FSectLists.RemoveAll();
  185. try
  186. {
  187. pADO = new TADOQuery(NULL);
  188. pADO->Close();
  189. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  190. pADO->SQL->Clear();
  191. pADO->SQL->Text = sQry;
  192. pADO->Open();
  193. for( ; !pADO->Eof; pADO->Next())
  194. {
  195. TItsAvi *pObj = new TItsAvi();
  196. pObj->AVI_CTLR_MNGM_NMBR= pADO->FieldByName("AVI_CTLR_MNGM_NMBR")->AsString;
  197. pObj->AVI_ID = pADO->FieldByName("AVI_ID")->AsString;
  198. pObj->LINK_ID = pADO->FieldByName("LINK_ID")->AsString;
  199. pObj->AVI_LCTN_NM = pADO->FieldByName("AVI_LCTN_NM")->AsString;
  200. pObj->AVI_VALD_YN = pADO->FieldByName("AVI_VALD_YN")->AsString;
  201. pObj->AVI_CTLR_IP = pADO->FieldByName("AVI_CTLR_IP")->AsString;
  202. pObj->AVI_CTLR_CMNC_PORT= pADO->FieldByName("AVI_CTLR_CMNC_PORT")->AsString;
  203. pObj->AVI_MAIN_CTLR_YN = pADO->FieldByName("AVI_MAIN_CTLR_YN")->AsString;
  204. pObj->AVI_MNGM_LANE_NUM = pADO->FieldByName("AVI_MNGM_LANE_NUM")->AsString;
  205. pObj->AVI_CMRA_NUM = pADO->FieldByName("AVI_CMRA_NUM")->AsString;
  206. pObj->AVI_DTCT_NUM = pADO->FieldByName("AVI_DTCT_NUM")->AsString;
  207. pObj->AVI_DTCT_NM = pADO->FieldByName("AVI_DTCT_NM")->AsString;
  208. pObj->AVI_CLCT_CYCL = pADO->FieldByName("AVI_CLCT_CYCL")->AsString;
  209. pObj->AVI_LAMP_AUTO_YN = pADO->FieldByName("AVI_LAMP_AUTO_YN")->AsString;
  210. pObj->AVI_LAMP_ON_HMS = pADO->FieldByName("AVI_LAMP_ON_HMS")->AsString;
  211. pObj->AVI_LAMP_OFF_HMS = pADO->FieldByName("AVI_LAMP_OFF_HMS")->AsString;
  212. pObj->AVI_LAMP_ON_YN = pADO->FieldByName("AVI_LAMP_ON_YN")->AsString;
  213. pObj->X_CRDN = pADO->FieldByName("X_CRDN")->AsString;
  214. pObj->Y_CRDN = pADO->FieldByName("Y_CRDN")->AsString;
  215. pObj->RMRK = pADO->FieldByName("RMRK")->AsString;
  216. pObj->DEL_YN = pADO->FieldByName("DEL_YN")->AsString;
  217. pObj->FRST_REGR_NMBR = pADO->FieldByName("FRST_REGR_NMBR")->AsString;
  218. pObj->FRST_RGST_DT = pADO->FieldByName("FRST_RGST_DT")->AsString;
  219. pObj->LAST_CRPR_NMBR = pADO->FieldByName("LAST_CRPR_NMBR")->AsString;
  220. pObj->LAST_CRCT_DT = pADO->FieldByName("LAST_CRCT_DT")->AsString;
  221. FLists.Push(pObj->AVI_CTLR_MNGM_NMBR, pObj);
  222. pObj->Completed = true;
  223. pObj->MEM_DEL = "N";
  224. }
  225. }
  226. catch(EDatabaseError &E)
  227. {
  228. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  229. DBERRORMSG("TItsAviManager::LoadFromDb", 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("TItsAviManager::LoadFromDb", 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. FLists.UnLock();
  247. }
  248. return true;
  249. }
  250. //---------------------------------------------------------------------------
  251. bool TItsAviManager::LoadFromDtctDb(TADOConnection *ADbConn/*=NULL*/)
  252. {
  253. String sQry;
  254. TADOQuery *pADO = NULL;
  255. sQry = "SELECT * \r\n"
  256. " FROM TB_AVI_DTCT_MSTR \r\n";
  257. //" WHERE DEL_YN = 'N' \r\n"
  258. //" ORDER BY AVI_CTLR_MNGM_NMBR, AVI_DTCT_NMBR \r\n";
  259. try
  260. {
  261. TItsAvi *pAvi;
  262. FLists.Lock();
  263. try
  264. {
  265. pADO = new TADOQuery(NULL);
  266. pADO->Close();
  267. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  268. pADO->SQL->Clear();
  269. pADO->SQL->Text = sQry;
  270. pADO->Open();
  271. for( ; !pADO->Eof; pADO->Next())
  272. {
  273. String CTLR_MNGM_NMBR = pADO->FieldByName("AVI_CTLR_MNGM_NMBR")->AsString;
  274. pAvi = FLists.Find(CTLR_MNGM_NMBR);
  275. if (!pAvi) continue;
  276. TItsAviDtct *pObj = new TItsAviDtct();
  277. pObj->CTLR_MNGM_NMBR = CTLR_MNGM_NMBR;
  278. pObj->DTCT_NMBR = pADO->FieldByName("AVI_DTCT_NMBR")->AsString;
  279. pObj->DTCT_NM = pADO->FieldByName("AVI_DTCT_NM")->AsString;
  280. pObj->DTCT_TYPE_CD = pADO->FieldByName("DTCT_TYPE_CD")->AsString;
  281. pObj->ISTL_LANE = pADO->FieldByName("ISTL_LANE")->AsString;
  282. pObj->USE_YN = pADO->FieldByName("USE_YN")->AsString;
  283. pObj->DEL_YN = pADO->FieldByName("DEL_YN")->AsString;
  284. pObj->MAX_TFVL = pADO->FieldByName("MAX_TFVL")->AsInteger;
  285. pObj->MIN_TFVL = pADO->FieldByName("MIN_TFVL")->AsInteger;
  286. pObj->MAX_OCPY_RATE = pADO->FieldByName("MAX_OCPY_RATE")->AsFloat;
  287. pObj->MIN_OCPY_RATE = pADO->FieldByName("MIN_OCPY_RATE")->AsFloat;
  288. pObj->MIN_SPED = pADO->FieldByName("MIN_SPED")->AsInteger;
  289. pObj->MAX_SPED = pADO->FieldByName("MAX_SPED")->AsInteger;
  290. pAvi->FDtctLists.Push(pObj->DTCT_NMBR, pObj);
  291. pObj->Completed = true;
  292. pObj->MEM_DEL = "N";
  293. }
  294. }
  295. catch(EDatabaseError &E)
  296. {
  297. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  298. DBERRORMSG("TItsAviManager::LoadFromDtctDb", String(E.ClassName()), E.Message, sQry);
  299. throw Exception(String(E.ClassName()) + E.Message);
  300. }
  301. catch(Exception &exception)
  302. {
  303. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  304. DBERRORMSG("TItsAviManager::LoadFromDtctDb", String(exception.ClassName()), exception.Message, sQry);
  305. throw Exception(String(exception.ClassName()) + exception.Message);
  306. }
  307. }
  308. __finally
  309. {
  310. if (pADO)
  311. {
  312. pADO->Close();
  313. delete pADO;
  314. }
  315. FLists.UnLock();
  316. }
  317. return true;
  318. }
  319. //---------------------------------------------------------------------------
  320. bool TItsAviManager::LoadFromSectDb(TADOConnection *ADbConn/*=NULL*/)
  321. {
  322. String sQry;
  323. TADOQuery *pADO = NULL;
  324. sQry = "SELECT A.AVI_CTLR_MNGM_NMBR, \r\n"
  325. " A.AVI_SECT_NMBR, \r\n"
  326. " A.ORD, \r\n"
  327. " B.AVI_SECT_NMBR, \r\n"
  328. " B.STRT_SPOT_NM, \r\n"
  329. " B.END_SPOT_NM, \r\n"
  330. " B.AVI_SECT_NM, \r\n"
  331. " B.AVI_SECT_DSTC, \r\n"
  332. " B.SHRT_PASS_HH, \r\n"
  333. " B.LNST_PASS_HH, \r\n"
  334. " B.SPOT_NUM, \r\n"
  335. " B.STND_DRFT_VAL, \r\n"
  336. " B.MIN_SPED, \r\n"
  337. " B.MAX_SPED, \r\n"
  338. " B.SMTH_FCTR, \r\n"
  339. " B.DEL_YN, \r\n"
  340. " B.FRST_REGR_NMBR, \r\n"
  341. " B.FRST_RGST_DT, \r\n"
  342. " B.LAST_CRPR_NMBR, \r\n"
  343. " B.LAST_CRCT_DT \r\n"
  344. " FROM TB_AVI_SECT_CNFG A, \r\n"
  345. " TB_AVI_SECT_MSTR B \r\n"
  346. " WHERE A.AVI_SECT_NMBR = B.AVI_SECT_NMBR \r\n"
  347. " ORDER BY A.AVI_CTLR_MNGM_NMBR, A.ORD \r\n";
  348. try
  349. {
  350. TItsAvi *pAvi;
  351. FLists.Lock();
  352. try
  353. {
  354. pADO = new TADOQuery(NULL);
  355. pADO->Close();
  356. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  357. pADO->SQL->Clear();
  358. pADO->SQL->Text = sQry;
  359. pADO->Open();
  360. for( ; !pADO->Eof; pADO->Next())
  361. {
  362. String AVI_CTLR_MNGM_NMBR = pADO->FieldByName("AVI_CTLR_MNGM_NMBR")->AsString;
  363. pAvi = FLists.Find(AVI_CTLR_MNGM_NMBR);
  364. if (!pAvi) continue;
  365. TItsAviSect *pObj = new TItsAviSect();
  366. pObj->AVI_CTLR_MNGM_NMBR = AVI_CTLR_MNGM_NMBR;
  367. pObj->ORD = pADO->FieldByName("ORD")->AsInteger;
  368. pObj->AVI_SECT_NMBR = pADO->FieldByName("AVI_SECT_NMBR")->AsString;
  369. pObj->STRT_SPOT_NM = pADO->FieldByName("STRT_SPOT_NM")->AsString;
  370. pObj->END_SPOT_NM = pADO->FieldByName("END_SPOT_NM")->AsString;
  371. pObj->AVI_SECT_NM = pADO->FieldByName("AVI_SECT_NM")->AsString;
  372. pObj->AVI_SECT_DSTC = pADO->FieldByName("AVI_SECT_DSTC")->AsString;
  373. pObj->SHRT_PASS_HH = pADO->FieldByName("SHRT_PASS_HH")->AsString;
  374. pObj->LNST_PASS_HH = pADO->FieldByName("LNST_PASS_HH")->AsString;
  375. pObj->SPOT_NUM = pADO->FieldByName("SPOT_NUM")->AsString;
  376. pObj->STND_DRFT_VAL = pADO->FieldByName("STND_DRFT_VAL")->AsString;
  377. pObj->MIN_SPED = pADO->FieldByName("MIN_SPED")->AsString;
  378. pObj->MAX_SPED = pADO->FieldByName("MAX_SPED")->AsString;
  379. pObj->SMTH_FCTR = pADO->FieldByName("SMTH_FCTR")->AsString;
  380. pObj->DEL_YN = pADO->FieldByName("DEL_YN")->AsString;
  381. pObj->FRST_REGR_NMBR = pADO->FieldByName("FRST_REGR_NMBR")->AsString;
  382. pObj->FRST_RGST_DT = pADO->FieldByName("FRST_RGST_DT")->AsString;
  383. pObj->LAST_CRPR_NMBR = pADO->FieldByName("LAST_CRPR_NMBR")->AsString;
  384. pObj->LAST_CRCT_DT = pADO->FieldByName("LAST_CRCT_DT")->AsString;
  385. pAvi->FSubLists.Push(pObj->AVI_SECT_NMBR, pObj);
  386. pObj->Completed = true;
  387. pObj->MEM_DEL = "N";
  388. TItsAviSect *pTmpObj = FSectLists.Find(pObj->AVI_SECT_NMBR);
  389. if (!pTmpObj)
  390. {
  391. TItsAviSect *pTmpObj = new TItsAviSect();
  392. pTmpObj->AVI_CTLR_MNGM_NMBR = pObj->AVI_CTLR_MNGM_NMBR;
  393. pTmpObj->ORD = pObj->ORD;
  394. pTmpObj->AVI_SECT_NMBR = pObj->AVI_SECT_NMBR;
  395. pTmpObj->STRT_SPOT_NM = pObj->STRT_SPOT_NM;
  396. pTmpObj->END_SPOT_NM = pObj->END_SPOT_NM;
  397. pTmpObj->AVI_SECT_NM = pObj->AVI_SECT_NM;
  398. pTmpObj->AVI_SECT_DSTC = pObj->AVI_SECT_DSTC;
  399. pTmpObj->SHRT_PASS_HH = pObj->SHRT_PASS_HH;
  400. pTmpObj->LNST_PASS_HH = pObj->LNST_PASS_HH;
  401. pTmpObj->SPOT_NUM = pObj->SPOT_NUM;
  402. pTmpObj->STND_DRFT_VAL = pObj->STND_DRFT_VAL;
  403. pTmpObj->MIN_SPED = pObj->MIN_SPED;
  404. pTmpObj->MAX_SPED = pObj->MAX_SPED;
  405. pTmpObj->SMTH_FCTR = pObj->SMTH_FCTR;
  406. pTmpObj->DEL_YN = pObj->DEL_YN;
  407. pTmpObj->FRST_REGR_NMBR = pObj->FRST_REGR_NMBR;
  408. pTmpObj->FRST_RGST_DT = pObj->FRST_RGST_DT;
  409. pTmpObj->LAST_CRPR_NMBR = pObj->LAST_CRPR_NMBR;
  410. pTmpObj->LAST_CRCT_DT = pObj->LAST_CRCT_DT;
  411. pTmpObj->Completed = true;
  412. pTmpObj->MEM_DEL = "N";
  413. FSectLists.Push(pTmpObj->AVI_SECT_NMBR, pTmpObj);
  414. }
  415. }
  416. }
  417. catch(EDatabaseError &E)
  418. {
  419. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  420. DBERRORMSG("TItsAviManager::LoadFromSectDb", String(E.ClassName()), E.Message, sQry);
  421. throw Exception(String(E.ClassName()) + E.Message);
  422. }
  423. catch(Exception &exception)
  424. {
  425. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  426. DBERRORMSG("TItsAviManager::LoadFromSectDb", String(exception.ClassName()), exception.Message, sQry);
  427. throw Exception(String(exception.ClassName()) + exception.Message);
  428. }
  429. }
  430. __finally
  431. {
  432. if (pADO)
  433. {
  434. pADO->Close();
  435. delete pADO;
  436. }
  437. FLists.UnLock();
  438. }
  439. return true;
  440. }
  441. //---------------------------------------------------------------------------
  442. bool TItsAviManager::LoadFromSectLinkDb(TADOConnection *ADbConn/*=NULL*/)
  443. {
  444. String sQry;
  445. TADOQuery *pADO = NULL;
  446. sQry = "SELECT A.AVI_CTLR_MNGM_NMBR, \r\n"
  447. " A.AVI_SECT_NMBR, \r\n"
  448. " B.LINK_ID, \r\n"
  449. " B.ORD \r\n"
  450. " FROM TB_AVI_SECT_CNFG A, \r\n"
  451. " TB_AVI_SECT_LINK B \r\n"
  452. " WHERE A.AVI_SECT_NMBR = B.AVI_SECT_NMBR \r\n"
  453. " ORDER BY A.AVI_CTLR_MNGM_NMBR, A.AVI_SECT_NMBR, B.ORD \r\n";
  454. try
  455. {
  456. TItsAvi *pAvi;
  457. TItsAviSect *pAviSect;
  458. FLists.Lock();
  459. try
  460. {
  461. pADO = new TADOQuery(NULL);
  462. pADO->Close();
  463. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  464. pADO->SQL->Clear();
  465. pADO->SQL->Text = sQry;
  466. pADO->Open();
  467. for( ; !pADO->Eof; pADO->Next())
  468. {
  469. String AVI_CTLR_MNGM_NMBR = pADO->FieldByName("AVI_CTLR_MNGM_NMBR")->AsString;
  470. pAvi = FLists.Find(AVI_CTLR_MNGM_NMBR);
  471. if (!pAvi) continue;
  472. String AVI_SECT_NMBR = pADO->FieldByName("AVI_SECT_NMBR")->AsString;
  473. pAviSect = pAvi->FSubLists.Find(AVI_SECT_NMBR);
  474. if (!pAviSect) continue;
  475. TItsAviLink *pObj = new TItsAviLink();
  476. pObj->AVI_CTLR_MNGM_NMBR = AVI_CTLR_MNGM_NMBR;
  477. pObj->AVI_SECT_NMBR = AVI_SECT_NMBR;
  478. pObj->LINK_ID = pADO->FieldByName("LINK_ID")->AsString;
  479. pObj->ORD = pADO->FieldByName("ORD")->AsInteger;
  480. pAviSect->FLinkLists.Push(pObj->ORD, pObj);
  481. pObj->Completed = true;
  482. pObj->MEM_DEL = "N";
  483. }
  484. }
  485. catch(EDatabaseError &E)
  486. {
  487. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  488. DBERRORMSG("TItsAviManager::LoadFromSectLinkDb", String(E.ClassName()), E.Message, sQry);
  489. throw Exception(String(E.ClassName()) + E.Message);
  490. }
  491. catch(Exception &exception)
  492. {
  493. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  494. DBERRORMSG("TItsAviManager::LoadFromSectLinkDb", String(exception.ClassName()), exception.Message, sQry);
  495. throw Exception(String(exception.ClassName()) + exception.Message);
  496. }
  497. }
  498. __finally
  499. {
  500. if (pADO)
  501. {
  502. pADO->Close();
  503. delete pADO;
  504. }
  505. FLists.UnLock();
  506. }
  507. return true;
  508. }
  509. //---------------------------------------------------------------------------
  510. bool TItsAviManager::GetNextAviId(String &ANewId, TADOConnection *ADbConn/*=NULL*/)
  511. {
  512. String sQry;
  513. TADOQuery *pADO = NULL;
  514. sQry = "SELECT TO_NUMBER(CASE WHEN EXISTS (SELECT 1 FROM TB_AVI_CTLR) \r\n"
  515. " THEN (SELECT TRIM(MAX(TO_NUMBER(AVI_CTLR_MNGM_NMBR)) + 1) \r\n"
  516. " FROM TB_AVI_CTLR) \r\n"
  517. " ELSE '1' END) NEWID \r\n"
  518. " FROM DUAL \r\n";
  519. ANewId = "";
  520. try
  521. {
  522. try
  523. {
  524. pADO = new TADOQuery(NULL);
  525. pADO->Close();
  526. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  527. pADO->SQL->Clear();
  528. pADO->SQL->Text = sQry;
  529. pADO->Open();
  530. ANewId = pADO->FieldByName("NEWID")->AsString;
  531. return true;
  532. }
  533. catch(EDatabaseError &E)
  534. {
  535. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  536. DBERRORMSG("TItsAviManager::GetNextAviId", String(E.ClassName()), E.Message, sQry);
  537. throw Exception(String(E.ClassName()) + E.Message);
  538. }
  539. catch(Exception &exception)
  540. {
  541. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  542. DBERRORMSG("TItsAviManager::GetNextAviId", String(exception.ClassName()), exception.Message, sQry);
  543. throw Exception(String(exception.ClassName()) + exception.Message);
  544. }
  545. }
  546. __finally
  547. {
  548. if (pADO)
  549. {
  550. pADO->Close();
  551. delete pADO;
  552. }
  553. }
  554. return false;
  555. }
  556. //---------------------------------------------------------------------------
  557. bool TItsAviManager::GetNextAviSectId(String &ANewId, TADOConnection *ADbConn/*=NULL*/)
  558. {
  559. String sQry;
  560. TADOQuery *pADO = NULL;
  561. sQry = "SELECT TO_NUMBER(CASE WHEN EXISTS (SELECT 1 FROM TB_AVI_SECT_MSTR) \r\n"
  562. " THEN (SELECT TRIM(MAX(TO_NUMBER(AVI_SECT_NMBR)) + 1) \r\n"
  563. " FROM TB_AVI_SECT_MSTR) \r\n"
  564. " ELSE '1' END) NEWID \r\n"
  565. " FROM DUAL \r\n";
  566. ANewId = "";
  567. try
  568. {
  569. try
  570. {
  571. pADO = new TADOQuery(NULL);
  572. pADO->Close();
  573. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  574. pADO->SQL->Clear();
  575. pADO->SQL->Text = sQry;
  576. pADO->Open();
  577. ANewId = pADO->FieldByName("NEWID")->AsString;
  578. return true;
  579. }
  580. catch(EDatabaseError &E)
  581. {
  582. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  583. DBERRORMSG("TItsAviManager::GetNextAviSectId", String(E.ClassName()), E.Message, sQry);
  584. throw Exception(String(E.ClassName()) + E.Message);
  585. }
  586. catch(Exception &exception)
  587. {
  588. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  589. DBERRORMSG("TItsAviManager::GetNextAviSectId", String(exception.ClassName()), exception.Message, sQry);
  590. throw Exception(String(exception.ClassName()) + exception.Message);
  591. }
  592. }
  593. __finally
  594. {
  595. if (pADO)
  596. {
  597. pADO->Close();
  598. delete pADO;
  599. }
  600. }
  601. return false;
  602. }
  603. //---------------------------------------------------------------------------
  604. bool TItsAviManager::DeleteAvi(TItsAvi *AObj, TADOConnection *ADbConn/*=NULL*/)
  605. {
  606. String sQry;
  607. TADOQuery *pADO = NULL;
  608. sQry = "UPDATE TB_AVI_CTLR \r\n"
  609. " SET DEL_YN = 'Y' \r\n"
  610. " WHERE ID = :p01 \r\n";
  611. try
  612. {
  613. FLists.Lock();
  614. try
  615. {
  616. pADO = new TADOQuery(NULL);
  617. pADO->Close();
  618. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  619. pADO->SQL->Clear();
  620. pADO->SQL->Text = sQry;
  621. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_CTLR_MNGM_NMBR;
  622. pADO->ExecSQL();
  623. sQry = "DELETE TB_FCLT_INFR \r\n"
  624. " WHERE FCLT_ID = :p01 \r\n";
  625. //" AND FCLT_TYPE = 'AVI' \r\n";
  626. pADO->SQL->Clear();
  627. pADO->SQL->Text = sQry;
  628. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_CTLR_MNGM_NMBR;
  629. pADO->ExecSQL();
  630. return true;
  631. }
  632. catch(EDatabaseError &E)
  633. {
  634. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  635. DBERRORMSG("TItsAviManager::DeleteAvi", String(E.ClassName()), E.Message, sQry);
  636. throw Exception(String(E.ClassName()) + E.Message);
  637. }
  638. catch(Exception &exception)
  639. {
  640. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  641. DBERRORMSG("TItsAviManager::DeleteAvi", String(exception.ClassName()), exception.Message, sQry);
  642. throw Exception(String(exception.ClassName()) + exception.Message);
  643. }
  644. }
  645. __finally
  646. {
  647. if (pADO)
  648. {
  649. pADO->Close();
  650. delete pADO;
  651. }
  652. FLists.UnLock();
  653. }
  654. return true;
  655. }
  656. //---------------------------------------------------------------------------
  657. bool TItsAviManager::UpdateAvi(TItsAvi *AObj, TADOConnection *ADbConn/*=NULL*/)
  658. {
  659. String sQry;
  660. TADOQuery *pADO = NULL;
  661. sQry = "UPDATE TB_AVI_CTLR \r\n"
  662. " SET AVI_ID = :p02, \r\n"
  663. " LINK_ID = :p03, \r\n"
  664. " AVI_LCTN_NM = :p04, \r\n"
  665. " AVI_VALD_YN = :p05, \r\n"
  666. " AVI_CTLR_IP = :p06, \r\n"
  667. " AVI_CTLR_CMNC_PORT = :p07, \r\n"
  668. " AVI_MAIN_CTLR_YN = :p08, \r\n"
  669. " AVI_MNGM_LANE_NUM = :p09, \r\n"
  670. " AVI_CMRA_NUM = :p10, \r\n"
  671. " AVI_DTCT_NUM = :p11, \r\n"
  672. " AVI_DTCT_NM = :p12, \r\n"
  673. " AVI_CLCT_CYCL = :p13, \r\n"
  674. " AVI_LAMP_AUTO_YN = :p14, \r\n"
  675. " AVI_LAMP_ON_HMS = :p15, \r\n"
  676. " AVI_LAMP_OFF_HMS = :p16, \r\n"
  677. " AVI_LAMP_ON_YN = :p17, \r\n"
  678. " X_CRDN = :p18, \r\n"
  679. " Y_CRDN = :p19, \r\n"
  680. " RMRK = :p20, \r\n"
  681. " DEL_YN = :p21 \r\n"
  682. " WHERE AVI_CTLR_MNGM_NMBR = :p01 \r\n";
  683. try
  684. {
  685. FLists.Lock();
  686. try
  687. {
  688. pADO = new TADOQuery(NULL);
  689. pADO->Close();
  690. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  691. pADO->SQL->Clear();
  692. pADO->SQL->Text = sQry;
  693. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_CTLR_MNGM_NMBR;
  694. pADO->Parameters->ParamByName("p02")->Value = AObj->AVI_ID;
  695. pADO->Parameters->ParamByName("p03")->Value = AObj->LINK_ID;
  696. pADO->Parameters->ParamByName("p04")->Value = AObj->AVI_LCTN_NM;
  697. pADO->Parameters->ParamByName("p05")->Value = AObj->AVI_VALD_YN;
  698. pADO->Parameters->ParamByName("p06")->Value = AObj->AVI_CTLR_IP;
  699. pADO->Parameters->ParamByName("p07")->Value = AObj->AVI_CTLR_CMNC_PORT;
  700. pADO->Parameters->ParamByName("p08")->Value = AObj->AVI_MAIN_CTLR_YN;
  701. pADO->Parameters->ParamByName("p09")->Value = AObj->AVI_MNGM_LANE_NUM;
  702. pADO->Parameters->ParamByName("p10")->Value = AObj->AVI_CMRA_NUM;
  703. pADO->Parameters->ParamByName("p11")->Value = AObj->AVI_DTCT_NUM;
  704. pADO->Parameters->ParamByName("p12")->Value = AObj->AVI_DTCT_NM;
  705. pADO->Parameters->ParamByName("p13")->Value = AObj->AVI_CLCT_CYCL;
  706. pADO->Parameters->ParamByName("p14")->Value = AObj->AVI_LAMP_AUTO_YN;
  707. pADO->Parameters->ParamByName("p15")->Value = AObj->AVI_LAMP_ON_HMS;
  708. pADO->Parameters->ParamByName("p16")->Value = AObj->AVI_LAMP_OFF_HMS;
  709. pADO->Parameters->ParamByName("p17")->Value = AObj->AVI_LAMP_ON_YN;
  710. pADO->Parameters->ParamByName("p18")->Value = AObj->X_CRDN;
  711. pADO->Parameters->ParamByName("p19")->Value = AObj->Y_CRDN;
  712. pADO->Parameters->ParamByName("p20")->Value = AObj->RMRK;
  713. pADO->Parameters->ParamByName("p21")->Value = AObj->DEL_YN;
  714. pADO->ExecSQL();
  715. sQry = "UPDATE TB_FCLT_INFR \r\n"
  716. " SET FCLT_LCTN = :p02 \r\n"
  717. " WHERE FCLT_ID = :p01 \r\n";
  718. //" AND FCLT_TYPE = 'AVI' \r\n";
  719. pADO->SQL->Clear();
  720. pADO->SQL->Text = sQry;
  721. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_CTLR_MNGM_NMBR;
  722. pADO->Parameters->ParamByName("p02")->Value = AObj->AVI_LCTN_NM;
  723. pADO->ExecSQL();
  724. return true;
  725. }
  726. catch(EDatabaseError &E)
  727. {
  728. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  729. DBERRORMSG("TItsAviManager::UpdateAvi", String(E.ClassName()), E.Message, sQry);
  730. throw Exception(String(E.ClassName()) + E.Message);
  731. }
  732. catch(Exception &exception)
  733. {
  734. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  735. DBERRORMSG("TItsAviManager::UpdateAvi", String(exception.ClassName()), exception.Message, sQry);
  736. throw Exception(String(exception.ClassName()) + exception.Message);
  737. }
  738. }
  739. __finally
  740. {
  741. if (pADO)
  742. {
  743. pADO->Close();
  744. delete pADO;
  745. }
  746. FLists.UnLock();
  747. }
  748. return true;
  749. }
  750. //---------------------------------------------------------------------------
  751. bool TItsAviManager::InsertAvi(TItsAvi *AObj, TADOConnection *ADbConn/*=NULL*/)
  752. {
  753. String sQry;
  754. TADOQuery *pADO = NULL;
  755. sQry = "INSERT INTO TB_AVI_CTLR(AVI_CTLR_MNGM_NMBR, AVI_ID, LINK_ID, AVI_LCTN_NM, AVI_VALD_YN, AVI_CTLR_IP, \r\n"
  756. " AVI_CTLR_CMNC_PORT, AVI_MAIN_CTLR_YN, AVI_MNGM_LANE_NUM, AVI_CMRA_NUM, \r\n"
  757. " AVI_DTCT_NUM, AVI_DTCT_NM, AVI_CLCT_CYCL, AVI_LAMP_AUTO_YN, AVI_LAMP_ON_HMS, \r\n"
  758. " AVI_LAMP_OFF_HMS, AVI_LAMP_ON_YN, X_CRDN, Y_CRDN, RMRK, DEL_YN ) \r\n"
  759. " VALUES(:p01, :p02, :p03, :p04, :p05, :p06, \r\n"
  760. " :p07, :p08, :p09, :p10, \r\n"
  761. " :p11, :p12, :p13, :p14, :p15, \r\n"
  762. " :p16, :p17, :p18, :p19, :p20, :p21 ) \r\n";
  763. try
  764. {
  765. FLists.Lock();
  766. try
  767. {
  768. pADO = new TADOQuery(NULL);
  769. pADO->Close();
  770. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  771. pADO->SQL->Clear();
  772. pADO->SQL->Text = sQry;
  773. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_CTLR_MNGM_NMBR;
  774. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_CTLR_MNGM_NMBR;
  775. pADO->Parameters->ParamByName("p02")->Value = AObj->AVI_ID;
  776. pADO->Parameters->ParamByName("p03")->Value = AObj->LINK_ID;
  777. pADO->Parameters->ParamByName("p04")->Value = AObj->AVI_LCTN_NM;
  778. pADO->Parameters->ParamByName("p05")->Value = AObj->AVI_VALD_YN;
  779. pADO->Parameters->ParamByName("p06")->Value = AObj->AVI_CTLR_IP;
  780. pADO->Parameters->ParamByName("p07")->Value = AObj->AVI_CTLR_CMNC_PORT;
  781. pADO->Parameters->ParamByName("p08")->Value = AObj->AVI_MAIN_CTLR_YN;
  782. pADO->Parameters->ParamByName("p09")->Value = AObj->AVI_MNGM_LANE_NUM;
  783. pADO->Parameters->ParamByName("p10")->Value = AObj->AVI_CMRA_NUM;
  784. pADO->Parameters->ParamByName("p11")->Value = AObj->AVI_DTCT_NUM;
  785. pADO->Parameters->ParamByName("p12")->Value = AObj->AVI_DTCT_NM;
  786. pADO->Parameters->ParamByName("p13")->Value = AObj->AVI_CLCT_CYCL;
  787. pADO->Parameters->ParamByName("p14")->Value = AObj->AVI_LAMP_AUTO_YN;
  788. pADO->Parameters->ParamByName("p15")->Value = AObj->AVI_LAMP_ON_HMS;
  789. pADO->Parameters->ParamByName("p16")->Value = AObj->AVI_LAMP_OFF_HMS;
  790. pADO->Parameters->ParamByName("p17")->Value = AObj->AVI_LAMP_ON_YN;
  791. pADO->Parameters->ParamByName("p18")->Value = AObj->X_CRDN;
  792. pADO->Parameters->ParamByName("p19")->Value = AObj->Y_CRDN;
  793. pADO->Parameters->ParamByName("p20")->Value = AObj->RMRK;
  794. pADO->Parameters->ParamByName("p21")->Value = AObj->DEL_YN;
  795. pADO->ExecSQL();
  796. sQry = "INSERT INTO TB_FCLT_INFR(FCLT_ID, FCLT_TYPE, FCLT_LCTN, RSCE_YN, DEL_YN, USE_YEAR, AMT) \r\n"
  797. " VALUES(:p01, 'AVI', :p03, 'N', 'N', '0', '0') \r\n";
  798. pADO->SQL->Clear();
  799. pADO->SQL->Text = sQry;
  800. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_CTLR_MNGM_NMBR;
  801. pADO->Parameters->ParamByName("p03")->Value = AObj->AVI_LCTN_NM;
  802. pADO->ExecSQL();
  803. return true;
  804. }
  805. catch(EDatabaseError &E)
  806. {
  807. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  808. DBERRORMSG("TItsAviManager::InsertAvi", String(E.ClassName()), E.Message, sQry);
  809. throw Exception(String(E.ClassName()) + E.Message);
  810. }
  811. catch(Exception &exception)
  812. {
  813. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  814. DBERRORMSG("TItsAviManager::InsertAvi", String(exception.ClassName()), exception.Message, sQry);
  815. throw Exception(String(exception.ClassName()) + exception.Message);
  816. }
  817. }
  818. __finally
  819. {
  820. if (pADO)
  821. {
  822. pADO->Close();
  823. delete pADO;
  824. }
  825. FLists.UnLock();
  826. }
  827. return true;
  828. }
  829. //---------------------------------------------------------------------------
  830. bool TItsAviManager::DeleteAviSectSubTable(TItsAviSect *AObj, TADOConnection *ADbConn/*=NULL*/)
  831. {
  832. String sQry;
  833. TADOQuery *pADO = NULL;
  834. try
  835. {
  836. try
  837. {
  838. pADO = new TADOQuery(NULL);
  839. pADO->Close();
  840. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  841. sQry = "DELETE TB_AVI_SECT_LINK \r\n"
  842. " WHERE AVI_SECT_NMBR = :p01 \r\n";
  843. pADO->SQL->Clear();
  844. pADO->SQL->Text = sQry;
  845. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_SECT_NMBR;
  846. pADO->ExecSQL();
  847. return true;
  848. }
  849. catch(EDatabaseError &E)
  850. {
  851. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  852. DBERRORMSG("TItsAviManager::DeleteAviSectSubTable", String(E.ClassName()), E.Message, sQry);
  853. throw Exception(String(E.ClassName()) + E.Message);
  854. }
  855. catch(Exception &exception)
  856. {
  857. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  858. DBERRORMSG("TItsAviManager::DeleteAviSectSubTable", String(exception.ClassName()), exception.Message, sQry);
  859. throw Exception(String(exception.ClassName()) + exception.Message);
  860. }
  861. }
  862. __finally
  863. {
  864. if (pADO)
  865. {
  866. pADO->Close();
  867. delete pADO;
  868. }
  869. }
  870. return true;
  871. }
  872. //---------------------------------------------------------------------------
  873. bool TItsAviManager::DeleteAviSect(TItsAviSect *AObj, TADOConnection *ADbConn/*=NULL*/)
  874. {
  875. String sQry;
  876. TADOQuery *pADO = NULL;
  877. sQry = "UPDATE TB_AVI_SECT_MSTR \r\n"
  878. " SET DEL_YN = 'Y' \r\n"
  879. " WHERE AVI_SECT_NMBR = :p01 \r\n";
  880. try
  881. {
  882. DeleteAviSectSubTable(AObj, ADbConn);
  883. try
  884. {
  885. pADO = new TADOQuery(NULL);
  886. pADO->Close();
  887. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  888. pADO->SQL->Clear();
  889. pADO->SQL->Text = sQry;
  890. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_SECT_NMBR;
  891. pADO->ExecSQL();
  892. sQry = "DELETE TB_AVI_SECT_CNFG \r\n"
  893. " WHERE AVI_SECT_NMBR = :p01 \r\n"
  894. " AND AVI_CTLR_MNGM_NMBR = :p02 \r\n";
  895. pADO->SQL->Clear();
  896. pADO->SQL->Text = sQry;
  897. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_SECT_NMBR;
  898. pADO->Parameters->ParamByName("p02")->Value = AObj->AVI_CTLR_MNGM_NMBR;
  899. pADO->ExecSQL();
  900. return true;
  901. }
  902. catch(EDatabaseError &E)
  903. {
  904. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  905. DBERRORMSG("TItsAviManager::DeleteAviSect", String(E.ClassName()), E.Message, sQry);
  906. throw Exception(String(E.ClassName()) + E.Message);
  907. }
  908. catch(Exception &exception)
  909. {
  910. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  911. DBERRORMSG("TItsAviManager::DeleteAviSect", String(exception.ClassName()), exception.Message, sQry);
  912. throw Exception(String(exception.ClassName()) + exception.Message);
  913. }
  914. }
  915. __finally
  916. {
  917. if (pADO)
  918. {
  919. pADO->Close();
  920. delete pADO;
  921. }
  922. }
  923. return true;
  924. }
  925. //---------------------------------------------------------------------------
  926. bool TItsAviManager::SaveAviSect(TItsAviSect *AObj, TADOConnection *ADbConn/*=NULL*/)
  927. {
  928. String sQry;
  929. TADOQuery *pADO = NULL;
  930. sQry = "MERGE INTO TB_AVI_SECT_MSTR L \r\n"
  931. "USING (SELECT :p01 AS AVI_SECT_NMBR, \r\n"
  932. " :p02 AS STRT_SPOT_NM, \r\n"
  933. " :p03 AS END_SPOT_NM, \r\n"
  934. " :p04 AS AVI_SECT_NM, \r\n"
  935. " :p05 AS AVI_SECT_DSTC, \r\n"
  936. " :p06 AS SHRT_PASS_HH, \r\n"
  937. " :p07 AS LNST_PASS_HH, \r\n"
  938. " :p08 AS SPOT_NUM, \r\n"
  939. " :p09 AS STND_DRFT_VAL, \r\n"
  940. " :p10 AS MIN_SPED, \r\n"
  941. " :p11 AS MAX_SPED, \r\n"
  942. " :p12 AS SMTH_FCTR, \r\n"
  943. " :p13 AS DEL_YN \r\n"
  944. " FROM DUAL) M \r\n"
  945. " ON (L.AVI_SECT_NMBR = M.AVI_SECT_NMBR) \r\n"
  946. "WHEN MATCHED THEN \r\n"
  947. "UPDATE SET STRT_SPOT_NM = M.STRT_SPOT_NM, \r\n"
  948. " END_SPOT_NM = M.END_SPOT_NM, \r\n"
  949. " AVI_SECT_NM = M.AVI_SECT_NM, \r\n"
  950. " AVI_SECT_DSTC = M.AVI_SECT_DSTC, \r\n"
  951. " SHRT_PASS_HH = M.SHRT_PASS_HH, \r\n"
  952. " LNST_PASS_HH = M.LNST_PASS_HH, \r\n"
  953. " SPOT_NUM = M.SPOT_NUM, \r\n"
  954. " STND_DRFT_VAL = M.STND_DRFT_VAL, \r\n"
  955. " MIN_SPED = M.MIN_SPED, \r\n"
  956. " MAX_SPED = M.MAX_SPED, \r\n"
  957. " SMTH_FCTR = M.SMTH_FCTR, \r\n"
  958. " DEL_YN = M.DEL_YN \r\n"
  959. "WHEN NOT MATCHED THEN \r\n"
  960. "INSERT (AVI_SECT_NMBR, STRT_SPOT_NM, END_SPOT_NM, \r\n"
  961. " AVI_SECT_NM, AVI_SECT_DSTC, SHRT_PASS_HH, \r\n"
  962. " LNST_PASS_HH, SPOT_NUM, STND_DRFT_VAL, \r\n"
  963. " MIN_SPED, MAX_SPED, SMTH_FCTR, DEL_YN) \r\n"
  964. "VALUES (M.AVI_SECT_NMBR, M.STRT_SPOT_NM, M.END_SPOT_NM, \r\n"
  965. " M.AVI_SECT_NM, M.AVI_SECT_DSTC, M.SHRT_PASS_HH, \r\n"
  966. " M.LNST_PASS_HH, M.SPOT_NUM, M.STND_DRFT_VAL, \r\n"
  967. " M.MIN_SPED, M.MAX_SPED, M.SMTH_FCTR, M.DEL_YN) \r\n";
  968. try
  969. {
  970. //관련정보를 모두 삭제
  971. DeleteAviSectSubTable(AObj, ADbConn);
  972. try
  973. {
  974. pADO = new TADOQuery(NULL);
  975. pADO->Close();
  976. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  977. pADO->SQL->Clear();
  978. pADO->SQL->Text = sQry;
  979. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_SECT_NMBR;
  980. pADO->Parameters->ParamByName("p02")->Value = AObj->STRT_SPOT_NM;
  981. pADO->Parameters->ParamByName("p03")->Value = AObj->END_SPOT_NM;
  982. pADO->Parameters->ParamByName("p04")->Value = AObj->AVI_SECT_NM;
  983. pADO->Parameters->ParamByName("p05")->Value = AObj->AVI_SECT_DSTC;
  984. pADO->Parameters->ParamByName("p06")->Value = AObj->SHRT_PASS_HH;
  985. pADO->Parameters->ParamByName("p07")->Value = AObj->LNST_PASS_HH;
  986. pADO->Parameters->ParamByName("p08")->Value = AObj->SPOT_NUM;
  987. pADO->Parameters->ParamByName("p09")->Value = AObj->STND_DRFT_VAL;
  988. pADO->Parameters->ParamByName("p10")->Value = AObj->MIN_SPED;
  989. pADO->Parameters->ParamByName("p11")->Value = AObj->MAX_SPED;
  990. pADO->Parameters->ParamByName("p12")->Value = AObj->SMTH_FCTR;
  991. pADO->Parameters->ParamByName("p13")->Value = AObj->DEL_YN;
  992. pADO->ExecSQL();
  993. sQry = "MERGE INTO TB_AVI_SECT_CNFG L \r\n"
  994. "USING (SELECT :p01 AS AVI_CTLR_MNGM_NMBR, \r\n"
  995. " :p02 AS AVI_SECT_NMBR, \r\n"
  996. " :p03 AS ORD \r\n"
  997. " FROM DUAL) M \r\n"
  998. " ON (L.AVI_CTLR_MNGM_NMBR = M.AVI_CTLR_MNGM_NMBR \r\n"
  999. " AND L.AVI_SECT_NMBR = M.AVI_SECT_NMBR) \r\n"
  1000. "WHEN MATCHED THEN \r\n"
  1001. "UPDATE SET ORD = M.ORD \r\n"
  1002. "WHEN NOT MATCHED THEN \r\n"
  1003. "INSERT ( AVI_CTLR_MNGM_NMBR, AVI_SECT_NMBR, ORD) \r\n"
  1004. "VALUES (M.AVI_CTLR_MNGM_NMBR, M.AVI_SECT_NMBR, M.ORD) \r\n";
  1005. pADO->SQL->Clear();
  1006. pADO->SQL->Text = sQry;
  1007. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_CTLR_MNGM_NMBR;
  1008. pADO->Parameters->ParamByName("p02")->Value = AObj->AVI_SECT_NMBR;
  1009. pADO->Parameters->ParamByName("p03")->Value = AObj->ORD;
  1010. pADO->ExecSQL();
  1011. //링크구성정보 입력
  1012. sQry = "INSERT INTO TB_AVI_SECT_LINK (AVI_SECT_NMBR, LINK_ID, ORD) \r\n"
  1013. " VALUES (:p01, :p02, :p03 ) \r\n";
  1014. pADO->SQL->Clear();
  1015. pADO->SQL->Text = sQry;
  1016. FOR_STL(TItsAviLink *, pObj, AObj->FLinkLists)
  1017. {
  1018. pADO->Parameters->ParamByName("p01")->Value = AObj->AVI_SECT_NMBR;
  1019. pADO->Parameters->ParamByName("p02")->Value = pObj->LINK_ID;
  1020. pADO->Parameters->ParamByName("p03")->Value = pObj->ORD;
  1021. pADO->ExecSQL();
  1022. }
  1023. return true;
  1024. }
  1025. catch(EDatabaseError &E)
  1026. {
  1027. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  1028. DBERRORMSG("TItsAviManager::SaveAviSect", String(E.ClassName()), E.Message, sQry);
  1029. throw Exception(String(E.ClassName()) + E.Message);
  1030. }
  1031. catch(Exception &exception)
  1032. {
  1033. ::PostMessage(Application->MainForm->Handle, (UINT)(WM_USER+0xF4), (WPARAM)0xB2, (LPARAM)0xB2);
  1034. DBERRORMSG("TItsAviManager::SaveAviSect", String(exception.ClassName()), exception.Message, sQry);
  1035. throw Exception(String(exception.ClassName()) + exception.Message);
  1036. }
  1037. }
  1038. __finally
  1039. {
  1040. if (pADO)
  1041. {
  1042. pADO->Close();
  1043. delete pADO;
  1044. }
  1045. }
  1046. return true;
  1047. }
  1048. //---------------------------------------------------------------------------