--- dao/DaoAdresseService/src/dk/daoas/daoadresseservice/AdressSearch.java 2015/02/13 15:58:36 2285 +++ dao/DaoAdresseService/src/dk/daoas/daoadresseservice/AdressSearch.java 2015/02/14 08:43:45 2289 @@ -26,6 +26,8 @@ public SearchResult search(String postnrStr, String adresse) { +//long start1 = System.currentTimeMillis(); + int postnr=0; try { @@ -33,6 +35,7 @@ } catch (Exception E) { return new SearchResult(Status.ERROR_UNKNOWN_POSTAL); } +//long start2 = System.currentTimeMillis(); Map postnrVeje = searchPostnrVejnavnGadeid.get(postnr); @@ -40,23 +43,29 @@ return new SearchResult(Status.ERROR_UNKNOWN_POSTAL); } +//long start3 = System.currentTimeMillis(); + SplitResult split = AddressUtils.splitAdresse(adresse); - String vasketVejnavn = AddressUtils.vaskVejnavn( split.vej ); + String vasketVejnavn = AddressUtils.vaskVejnavn( split.vej ); if (split.husnr.length() == 0) { return new SearchResult(Status.ERROR_MISSING_HOUSENUMBER); } +//long start4 = System.currentTimeMillis(); Long gadeident = postnrVeje.get(vasketVejnavn); if (gadeident == null) { return new SearchResult(Status.ERROR_UNKNOWN_STREETNAME); - } + } +//long start5 = System.currentTimeMillis(); Map gade = searchGadeidentAdresser.get(gadeident); //Denne søgning må ikke fejle +//long start6 = System.currentTimeMillis(); String husnrSearch = "" + split.husnr + split.litra; Address addr = gade.get(husnrSearch); +//long start7 = System.currentTimeMillis(); if (addr == null) { return new SearchResult(Status.ERROR_UNKNOWN_ADDRESSPOINT); } @@ -68,6 +77,16 @@ if (addr.distributor.equals("LUKKET")) { return new SearchResult(Status.STATUS_NOT_COVERED); //Skal vi have en special status til Lukkede adresser ? } + +/* +System.out.println("Search2: " + (start2-start1) ); +System.out.println("Search3: " + (start3-start1) ); +System.out.println("Search4: " + (start4-start1) ); +System.out.println("Search5: " + (start5-start1) ); +System.out.println("Search6: " + (start6-start1) ); +System.out.println("Search7: " + (start7-start1) ); +*/ + return new SearchResult(addr); @@ -82,6 +101,7 @@ alleAdresser = DatabaseLayer.getAllAdresses(); + /* Mapper mellem db Row ID og adresse noden */ Map idAddressMap = new HashMap( alleAdresser.size() ); @@ -107,7 +127,7 @@ searchGadeidentAdresser.put(a.gadeid, gade); } String husnrSearch = "" + a.husnr + a.husnrbogstav; - gade.put(husnrSearch, a); + gade.put(husnrSearch, a); } @@ -163,15 +183,17 @@ orgAddress.distributor = targetAddress.distributor; } - - } + + // nu skal vi ikke bruge idAddressMap længere + idAddressMap = null; + ////////////////////////////////////////////////////////////////////////////////////// System.out.println("Build -- stage 3 - 100pct"); hundredePct = DatabaseLayer.get100PctList(); for (Address addr : alleAdresser) { - if (addr.daekningsType != DaekningsType.DAEKNING_IKKEDAEKKET) { + if (addr.daekningsType != DaekningsType.DAEKNING_IKKEDAEKKET) { continue; } @@ -192,6 +214,35 @@ addr.distributor = bean.distributor; } + //////////////////////////////////////////////////////////////////////////////////// + System.out.println("Build -- Gathering statistics"); + + int direkteCount = 0; + int extendedCount = 0; + int hundredePctCount = 0; + int ikkeDaekketCount = 0; + + for (Address addr : alleAdresser) { + switch (addr.daekningsType) { + case DAEKNING_DIREKTE: + direkteCount++; + break; + case DAEKNING_UDVIDET: + extendedCount++; + break; + case DAEKNING_100PCT: + hundredePctCount++; + break; + default: + ikkeDaekketCount++; + } + } + + System.out.println("Build: direkteCount: " + direkteCount); + System.out.println("Build: extendedCount: " + extendedCount); + System.out.println("Build: hundredePctCount: " + hundredePctCount); + System.out.println("Build: ikkeDaekketCount: " + ikkeDaekketCount); + System.out.println("Build Completed"); }