Mercurial > dive4elements > river
view flys-aft/src/main/java/de/intevation/aft/Rivers.java @ 4103:2305731f563c
Store W/Q in sets to prevent value duplications.
flys-aft/trunk@3633 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Sascha L. Teichmann <sascha.teichmann@intevation.de> |
---|---|
date | Mon, 09 Jan 2012 17:09:25 +0000 |
parents | b20b710aa86f |
children | a310aceb2e51 |
line wrap: on
line source
package de.intevation.aft; import java.util.Map; import java.util.HashMap; import java.util.List; import java.util.ArrayList; import java.sql.SQLException; import java.sql.ResultSet; import de.intevation.db.ConnectedStatements; import org.apache.log4j.Logger; public class Rivers { private static Logger log = Logger.getLogger(Rivers.class); public Rivers() { } public boolean sync(SyncContext context) throws SQLException { log.info("sync: rivers"); ConnectedStatements flysStatements = context.getFlysStatements(); ConnectedStatements aftStatements = context.getAftStatements(); Map<String, Integer> flysRivers = new HashMap<String, Integer>(); ResultSet flysRs = flysStatements .getStatement("select.river").executeQuery(); while (flysRs.next()) { Integer id = flysRs.getInt("id"); String name = flysRs.getString("name").toLowerCase(); flysRivers.put(name, id); } flysRs.close(); List<River> commonRivers = new ArrayList<River>(); ResultSet aftRs = aftStatements .getStatement("select.gewaesser").executeQuery(); while (aftRs.next()) { String name = aftRs.getString("NAME"); Integer id1 = flysRivers.get(name.toLowerCase()); if (id1 != null) { int id2 = aftRs.getInt("GEWAESSER_NR"); River river = new River(id1, id2, name); commonRivers.add(river); } } aftRs.close(); boolean modified = false; for (River river: commonRivers) { modified |= river.sync(context); } return modified; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :