CDSItsRoadInfoF.cpp 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350
  1. //---------------------------------------------------------------------------
  2. #pragma hdrstop
  3. #include "ITSDbF.h"
  4. #include "AppGlobalF.h"
  5. #include "CDSItsRoadInfoF.h"
  6. //---------------------------------------------------------------------------
  7. String REGCODE = "355";
  8. String REGNAME = "±¸¹Ì½Ã";
  9. #pragma package(smart_init)
  10. String __fastcall STCodeCondition::ToSQLOrString(String strField)
  11. {
  12. String strRet;
  13. int nCount = 0;
  14. if(true == bUse)
  15. {
  16. strRet += "( ";
  17. vector<String>::iterator it, itEnd = Codes.end();
  18. for(it = Codes.begin(); it != itEnd; ++it)
  19. {
  20. if(Codes.begin() != it)
  21. {
  22. strRet += " or ";
  23. }
  24. if(nCount >= 100)
  25. {
  26. strRet += " \n";
  27. nCount = 0;
  28. }
  29. strRet += strField + " = '";
  30. strRet += *it;
  31. strRet += "'";
  32. }
  33. strRet += ") ";
  34. }
  35. return strRet;
  36. }
  37. //------------------------------------------------------------------------------
  38. String __fastcall STCodeCondition::ToSQLInString(String strField)
  39. {
  40. String strRet;
  41. if(true == bUse)
  42. {
  43. if(strField.IsEmpty() == false)
  44. {
  45. strRet.sprintf(L" %s IN ( ", strField);
  46. }
  47. else
  48. {
  49. strRet = " IN ( ";
  50. }
  51. vector<String>::iterator it, itEnd = Codes.end();
  52. for(it = Codes.begin(); it != itEnd; ++it)
  53. {
  54. if(Codes.begin() != it)
  55. {
  56. strRet += ", ";
  57. }
  58. strRet += "'";
  59. strRet += *it;
  60. strRet += "'";
  61. }
  62. strRet += ") ";
  63. }
  64. return strRet;
  65. };
  66. //------------------------------------------------------------------------------
  67. TRLink::TRLink()
  68. {
  69. FShow = true;
  70. }
  71. //---------------------------------------------------------------------------
  72. void TRLink::Clear()
  73. {
  74. }
  75. //---------------------------------------------------------------------------
  76. TRLink::~TRLink()
  77. {
  78. }
  79. //---------------------------------------------------------------------------
  80. TRRoad::TRRoad()
  81. {
  82. FShow = true;
  83. }
  84. //---------------------------------------------------------------------------
  85. void TRRoad::Clear()
  86. {
  87. }
  88. //---------------------------------------------------------------------------
  89. TRRoad::~TRRoad()
  90. {
  91. }
  92. //---------------------------------------------------------------------------
  93. TRSido::TRSido()
  94. {
  95. FShow = true;
  96. }
  97. //---------------------------------------------------------------------------
  98. void TRSido::Clear()
  99. {
  100. }
  101. //---------------------------------------------------------------------------
  102. TRSido::~TRSido()
  103. {
  104. }
  105. //---------------------------------------------------------------------------
  106. //---------------------------------------------------------------------------
  107. TRLinkManager *RLinkManager = NULL;
  108. //---------------------------------------------------------------------------
  109. /*
  110. * User Manager
  111. */
  112. TRLinkManager::TRLinkManager()
  113. {
  114. FLoadLink = false;
  115. }
  116. //---------------------------------------------------------------------------
  117. TRLinkManager::~TRLinkManager()
  118. {
  119. FLists.RemoveAll();
  120. }
  121. //---------------------------------------------------------------------------
  122. bool TRLinkManager::LoadSido(TADOConnection *ADbConn/*=NULL*/)
  123. {
  124. #if 0
  125. String sQry;
  126. TADOQuery *pADO = NULL;
  127. String sSido = REGCODE;
  128. sQry = "SELECT VALUE, CODE, PCODE "
  129. " FROM CODEDEFINE "
  130. " WHERE PCODEKIND = 'CTY' "
  131. " AND CODEKIND = 'RGN' "
  132. " AND PCODE = " + sSido +
  133. " AND USEYN = 1 "
  134. " ORDER BY VALUE ";
  135. try
  136. {
  137. FLists.Lock();
  138. FLists.RemoveAll();
  139. try
  140. {
  141. pADO = new TADOQuery(NULL);
  142. pADO->Close();
  143. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  144. pADO->SQL->Clear();
  145. pADO->SQL->Text = sQry;
  146. pADO->Prepared = true;
  147. pADO->Open();
  148. for( ; !pADO->Eof; pADO->Next())
  149. {
  150. TRSido *pObj = new TRSido();
  151. pObj->LINKID = pADO->FieldByName("CODE")->AsString;
  152. pObj->NAME = pADO->FieldByName("VALUE")->AsString;
  153. FLists.Push(pObj->LINKID, pObj);
  154. }
  155. }
  156. catch(EDatabaseError &E)
  157. {
  158. throw Exception(String(E.ClassName()) + E.Message);
  159. }
  160. catch(Exception &exception)
  161. {
  162. throw Exception(String(exception.ClassName()) + exception.Message);
  163. }
  164. }
  165. __finally
  166. {
  167. if (pADO)
  168. {
  169. pADO->Close();
  170. delete pADO;
  171. }
  172. FLists.UnLock();
  173. }
  174. #else
  175. try
  176. {
  177. FLists.Lock();
  178. FLists.RemoveAll();
  179. TRSido *pObj = new TRSido();
  180. pObj->LINKID = REGCODE;
  181. pObj->NAME = REGNAME;
  182. FLists.Push(pObj->LINKID, pObj);
  183. }
  184. __finally
  185. {
  186. FLists.UnLock();
  187. }
  188. #endif
  189. return true;
  190. }
  191. //---------------------------------------------------------------------------
  192. bool TRLinkManager::LoadRoad(TADOConnection *ADbConn/*=NULL*/)
  193. {
  194. String sQry;
  195. TADOQuery *pADO = NULL;
  196. String sSido = "8";
  197. sQry = "SELECT SUBSTR(A.LINK_ID, 1, 3) AS LINKID, \r\n"
  198. " A.ROAD_NAME AS ROADNAME \r\n"
  199. " FROM TB_LINK A \r\n"
  200. " WHERE SUBSTR(A.LINK_ID, 1, 3) = '" + REGCODE + "' \r\n"
  201. " GROUP BY SUBSTR(A.LINK_ID, 1, 3), ROAD_NAME \r\n";
  202. TRSido *pSido;
  203. try
  204. {
  205. try
  206. {
  207. pADO = new TADOQuery(NULL);
  208. pADO->Close();
  209. pADO->Connection = (NULL != ADbConn) ? ADbConn : ITSDb_GetConnection();
  210. pADO->SQL->Clear();
  211. pADO->SQL->Text = sQry;
  212. pADO->Prepared = true;
  213. pADO->Open();
  214. for( ; !pADO->Eof; pADO->Next())
  215. {
  216. String sLinkId = pADO->FieldByName("LINKID")->AsString;
  217. pSido = FLists.Find(sLinkId);
  218. if (!pSido) continue;
  219. TRRoad *pObj = new TRRoad();
  220. pObj->LINKID = sLinkId;
  221. pObj->NAME = pADO->FieldByName("ROADNAME")->AsString;
  222. pSido->FRoads.Push(pObj->NAME, pObj);
  223. }
  224. }
  225. catch(EDatabaseError &E)
  226. {
  227. throw Exception(String(E.ClassName()) + E.Message);
  228. }
  229. catch(Exception &exception)
  230. {
  231. throw Exception(String(exception.ClassName()) + exception.Message);
  232. }
  233. }
  234. __finally
  235. {
  236. if (pADO)
  237. {
  238. pADO->Close();
  239. delete pADO;
  240. }
  241. }
  242. return true;
  243. }
  244. //---------------------------------------------------------------------------
  245. bool TRLinkManager::LoadLink(TADOConnection *ADbConn/*=NULL*/)
  246. {
  247. if (FLoadLink) return true;
  248. String sQry;
  249. TADOQuery *pADO = NULL;
  250. String sSido = REGCODE;
  251. sQry = "SELECT SUBSTR(A.LINK_ID, 1, 3) AS SIDOID, \r\n"
  252. " A.ROAD_NAME AS ROADNAME, A.LINK_ID AS LINKID, \r\n"
  253. " C.NODE_NAME AS STNODENAME, \r\n"
  254. " D.NODE_NAME AS EDNODENAME \r\n"
  255. " FROM TB_LINK A, \r\n"
  256. " TB_NODE C, TB_NODE D \r\n"
  257. " WHERE SUBSTR(A.LINK_ID, 1, 3) = '" + REGCODE + "' \r\n"
  258. " AND A.F_NODE_ID = C.NODE_ID \r\n"
  259. " AND A.T_NODE_ID = D.NODE_ID \r\n"
  260. " ORDER BY A.ROAD_NAME, A.LINK_ID \r\n";
  261. TRSido *pSido;
  262. TRRoad *pRoad;
  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 sSidoId = pADO->FieldByName("SIDOID")->AsString;
  277. pSido = FLists.Find(sSidoId);
  278. if (!pSido) continue;
  279. String sRoadName = pADO->FieldByName("ROADNAME")->AsString;
  280. pRoad = pSido->FRoads.Find(sRoadName);
  281. if (!pRoad) continue;
  282. TRLink *pObj = new TRLink();
  283. pObj->LINKID = pADO->FieldByName("LINKID")->AsString;
  284. pObj->STNODENAME = pADO->FieldByName("STNODENAME")->AsString;
  285. pObj->EDNODENAME = pADO->FieldByName("EDNODENAME")->AsString;
  286. pRoad->FLinks.Push(pObj->LINKID, pObj);
  287. }
  288. }
  289. catch(EDatabaseError &E)
  290. {
  291. throw Exception(String(E.ClassName()) + E.Message);
  292. }
  293. catch(Exception &exception)
  294. {
  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. }
  306. FLoadLink = true;
  307. return true;
  308. }
  309. //---------------------------------------------------------------------------