/[projects]/dao/DaoAdresseService/src/main/java/dk/daoas/daoadresseservice/db/DatabaseLayerImplementation.java
ViewVC logotype

Contents of /dao/DaoAdresseService/src/main/java/dk/daoas/daoadresseservice/db/DatabaseLayerImplementation.java

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2667 - (show annotations) (download)
Tue Aug 25 09:55:23 2015 UTC (8 years, 8 months ago) by torben
File size: 9705 byte(s)
Hotfix of log
1 package dk.daoas.daoadresseservice.db;
2
3 import java.sql.Connection;
4 import java.sql.PreparedStatement;
5 import java.sql.ResultSet;
6 import java.sql.SQLException;
7 import java.sql.Statement;
8 import java.util.ArrayList;
9 import java.util.HashMap;
10 import java.util.List;
11 import java.util.Map;
12
13 import dk.daoas.daoadresseservice.AddressUtils;
14 import dk.daoas.daoadresseservice.beans.Address;
15 import dk.daoas.daoadresseservice.beans.AliasBean;
16 import dk.daoas.daoadresseservice.beans.ExtendedBean;
17 import dk.daoas.daoadresseservice.beans.HundredePctBean;
18 import dk.daoas.daoadresseservice.beans.SearchResult;
19 import dk.daoas.daoadresseservice.util.DeduplicateHelper;
20
21 public class DatabaseLayerImplementation implements DatabaseLayer {
22
23 static boolean DEBUG = false;
24
25 @Override
26 public List<Address> getAllAdresses() throws SQLException {
27 String debugFilter = DatabaseLayerImplementation.DEBUG ? " AND postnr = 8700 " : "";
28
29 String sql =
30 "SELECT id,vejnavn,husnr,husnrbogstav,kommunekode,vejkode,postnr,gadeid,upper(distributor) AS distributor,dbkbane,koreliste,rute,korelisteloerdag,ruteloerdag,korelistesoendag,rutesoendag,latitude,longitude "
31 + "FROM fulddaekning.adressetabel "
32 + "WHERE gadeid IS NOT NULL "
33 + debugFilter
34 ;
35
36 try ( Connection conn = DBConnection.getConnection();
37 Statement stmt = conn.createStatement(java.sql.ResultSet.TYPE_FORWARD_ONLY, java.sql.ResultSet.CONCUR_READ_ONLY);
38 ) {
39 stmt.setFetchSize(Integer.MIN_VALUE);
40 ResultSet res = stmt.executeQuery(sql);
41
42 List<Address> list = new ArrayList<Address>(2600000);//initial capacity 2.6 mio
43
44 DeduplicateHelper<String> vejnavnCache = new DeduplicateHelper<String>();
45 DeduplicateHelper<String> husnrbogstavCache = new DeduplicateHelper<String>();
46 DeduplicateHelper<String> distributorCache = new DeduplicateHelper<String>();
47 DeduplicateHelper<String> korelisteCache = new DeduplicateHelper<String>();
48 DeduplicateHelper<String> ruteCache = new DeduplicateHelper<String>();
49
50
51 while (res.next()) {
52
53 Address a = new Address();
54 a.id = res.getInt(1);
55 a.vejnavn = vejnavnCache.getInstance( res.getString(2) );
56 a.husnr = (short) res.getInt(3);
57 a.husnrbogstav = husnrbogstavCache.getInstance( res.getString(4) );
58 a.kommunekode = (short) res.getInt(5);
59 a.vejkode = (short)res.getInt(6);
60 a.postnr = (short)res.getInt(7);
61 a.gadeid = res.getInt(8);
62 a.distributor = distributorCache.getInstance(res.getString(9));
63 a.dbkBane = (short) res.getInt(10);
64
65 a.koreliste = korelisteCache.getInstance( res.getString(11) );
66 a.rute = ruteCache.getInstance( res.getString(12) );
67 a.korelisteLordag = korelisteCache.getInstance( res.getString(13) );
68 a.ruteLordag = ruteCache.getInstance( res.getString(14) );
69 a.korelisteSondag = korelisteCache.getInstance( res.getString(15) );
70 a.ruteSondag = ruteCache.getInstance( res.getString(16) );
71
72 a.latitude = (float) res.getDouble(17);
73 a.longitude = (float) res.getDouble(18);
74
75 //a.vasketVejnavn = AddressUtils.vaskVejnavn(a.vejnavn);
76
77
78 //Ajourfør adresse objectets dækningstype
79 AddressUtils.updateDaekningstype(a);
80
81 list.add(a);
82 }
83 res.close();
84
85 System.out.println("Loaded " + list.size() + " adresses");
86
87 return list;
88 }
89 }
90
91 @Override
92 public List<AliasBean> getAliasList() throws SQLException {
93
94
95 String sql = "SELECT postnr,vejnavn,aliasvejnavn " +
96 "FROM bogleveringer.vejtabelprod "
97 ;
98
99 try ( Connection conn = DBConnection.getConnection();
100 Statement stmt = conn.createStatement(java.sql.ResultSet.TYPE_FORWARD_ONLY, java.sql.ResultSet.CONCUR_READ_ONLY);
101 ) {
102
103 stmt.setFetchSize(Integer.MIN_VALUE);
104
105 ResultSet res = stmt.executeQuery(sql);
106
107 DeduplicateHelper<String> vejCache = new DeduplicateHelper<String>();
108
109 List<AliasBean> list = new ArrayList<AliasBean>( 5000);
110 while (res.next()) {
111
112 AliasBean ab = new AliasBean();
113 ab.postnr = res.getShort(1);
114 ab.vejnavn = vejCache.getInstance( res.getString(2) );
115 ab.aliasVejnavn = vejCache.getInstance( res.getString(3) );
116
117 list.add(ab);
118 }
119
120 res.close();
121
122 System.out.println("Loaded " + list.size() + " aliase beans");
123
124 return list;
125 }
126
127 }
128
129 @Override
130 public List<ExtendedBean> getExtendedAdresslist() throws SQLException {
131 String debugFilter1 = DatabaseLayerImplementation.DEBUG ? " WHERE orgPostnr = 8700 " : "";
132 String debugFilter2 = DatabaseLayerImplementation.DEBUG ? " AND orgPostnr = 8700 " : "";
133
134
135 String sql = "select orgid, a.id as targetid, afstand, LOWER(type) as type from fulddaekning.afstand_anden_rute a " +
136 "join odbc.transporttype t " +
137 "on t.Art = 'Transpost' " +
138 "and ( (t.Type = 'Cykel' and a.Afstand < 1.001) or (t.Type = 'Scooter' and a.Afstand < 1.201) or (t.Type = 'Bil' and a.Afstand < 2.601) ) " +
139 "and t.Rute = a.Rute " +
140 debugFilter1 +
141
142 "UNION ALL " +
143
144 "SELECT orgid, a.id as targetid, afstand,'' as type FROM fulddaekning.afstand_anden_rute_bk a " +
145 "left join bogleveringer.postnummerdistributor d on d.PostNr = a.orgPostnr " +
146 "WHERE d.Distributor <> 10057 " +
147 debugFilter2
148 ;
149
150 try ( Connection conn = DBConnection.getConnection();
151 Statement stmt = conn.createStatement(java.sql.ResultSet.TYPE_FORWARD_ONLY, java.sql.ResultSet.CONCUR_READ_ONLY);
152 ) {
153
154
155 stmt.setFetchSize(Integer.MIN_VALUE);
156
157 ResultSet res = stmt.executeQuery(sql);
158
159 DeduplicateHelper<String> transportCache = new DeduplicateHelper<String>();
160
161 List<ExtendedBean> list = new ArrayList<ExtendedBean>( 350000); //Initial capacity 350K
162 while (res.next()) {
163
164 ExtendedBean eb = new ExtendedBean();
165 eb.orgId = res.getInt(1);
166 eb.targetId = res.getInt(2);
167 eb.afstand = (float) res.getDouble(3);
168 eb.transport = transportCache.getInstance(res.getString(4));
169
170 list.add(eb);
171 }
172
173 res.close();
174
175 System.out.println("Loaded " + list.size() + " extendedbeans");
176
177 return list;
178 }
179 }
180
181 @Override
182 public Map<Short,HundredePctBean> get100PctList() throws SQLException {
183 String sql = "SELECT postnr,UPPER(distributor) as distributor,rute,koreliste,dbkbane " +
184 "FROM bogleveringer.adresser_udenfor_daekning";
185
186 try ( Connection conn = DBConnection.getConnection();
187 Statement stmt = conn.createStatement(java.sql.ResultSet.TYPE_FORWARD_ONLY, java.sql.ResultSet.CONCUR_READ_ONLY);
188 ) {
189 ResultSet res = stmt.executeQuery(sql);
190
191 Map<Short, HundredePctBean> map = new HashMap<Short,HundredePctBean>();
192
193 DeduplicateHelper<String> distributorCache = new DeduplicateHelper<String>();
194
195 while (res.next()) {
196
197
198 HundredePctBean bean = new HundredePctBean();
199 bean.postnr = (short) res.getInt(1);
200 bean.distributor = distributorCache.getInstance(res.getString(2));
201 bean.rute = res.getString(3);
202 bean.koreliste = res.getString(4);
203 bean.dbkBane = (short)res.getInt(5);
204
205 map.put(bean.postnr, bean);
206 }
207
208 res.close();
209
210 System.out.println("Loaded " + map.size() + " 100pct beans");
211
212 return map;
213 }
214
215 }
216
217 @Override
218 public void saveRequestLog(String brugerid, String postnr, String adresse, String omdelingsdag, SearchResult result) throws SQLException {
219 String setVar = "set sql_mode = 'NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION' ";
220
221 String sql = "INSERT INTO logs.hentruteinformation (postnr,adresse,vejnavn,googlevejnavn,husnr,husnr_bogstav,etage,lejlighed,rest,brugerid,status, OmdelingDag, indlast) " +
222 "VALUES ( ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, NOW() )";
223
224
225
226 try ( Connection conn = DBConnection.getConnection();
227 Statement setStmt = conn.createStatement();
228 PreparedStatement stmt = conn.prepareStatement(sql);
229 ) {
230
231 setStmt.execute(setVar);
232
233
234 stmt.setInt( 1, safeInt(postnr) );
235 stmt.setString( 2, adresse);
236 stmt.setString( 3, result.splitResult.vej);
237 stmt.setString( 4, coalesce(result.googleVej,result.osmVej) );
238 stmt.setString( 5, nullify(result.splitResult.husnr) );
239 stmt.setString( 6, result.splitResult.litra);
240 stmt.setString( 7, result.splitResult.etage);
241 stmt.setString( 8, result.splitResult.lejlighed);
242 stmt.setString( 9, result.splitResult.resten);
243 stmt.setString(10, brugerid);
244 stmt.setInt(11, getStatusInt(result.status) );
245 stmt.setString(12, omdelingsdag);
246
247 stmt.executeUpdate();
248
249 }
250 }
251
252
253
254
255 private static int safeInt(String str) {
256 try {
257 return Integer.parseInt( str );
258 } catch (NumberFormatException e) {
259 return 0;
260 }
261 }
262
263 private static String nullify(String str) {
264 if (str == null)
265 return null;
266
267 if (str.equals("")) {
268 return null;
269 } else {
270 return str;
271 }
272 }
273
274 private static String coalesce(String s1, String s2) {
275 if (s1 != null)
276 return s1;
277
278 return s2;
279 }
280
281 public static int getStatusInt(SearchResult.Status status) {
282
283 switch (status) {
284 case ERROR_UNKNOWN_POSTAL:
285 return 20;
286 case ERROR_MISSING_HOUSENUMBER:
287 return 21;
288 case ERROR_POSTBOX:
289 return 22;
290 case ERROR_UNKNOWN_STREETNAME:
291 return 23;
292 case ERROR_UNKNOWN_ADDRESSPOINT:
293 return 24;
294 case STATUS_NOT_COVERED:
295 return 25;
296 case ERROR_INTERNAL: //
297 return 26;
298
299 case STATUS_OK:
300 return 30;
301
302 default:
303 return 31;
304 }
305 }
306
307 }

  ViewVC Help
Powered by ViewVC 1.1.20