Mercurial > dive4elements > river
changeset 768:87ac543c7ab9
When
looking up a gauge by km containment use precision of 1e-6.
flys-backend/trunk@2232 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Sascha L. Teichmann <sascha.teichmann@intevation.de> |
---|---|
date | Sun, 26 Jun 2011 12:16:36 +0000 (2011-06-26) |
parents | 5572d051347e |
children | 321b9e480f72 |
files | flys-backend/ChangeLog flys-backend/src/main/java/de/intevation/flys/model/River.java |
diffstat | 2 files changed, 11 insertions(+), 3 deletions(-) [+] |
line wrap: on
line diff
--- a/flys-backend/ChangeLog Wed Jun 22 08:56:09 2011 +0000 +++ b/flys-backend/ChangeLog Sun Jun 26 12:16:36 2011 +0000 @@ -1,3 +1,8 @@ +2011-06-26 Sascha L. Teichmann <sascha.teichmann@intevation.de> + + * src/main/java/de/intevation/flys/model/River.java: When + looking up a gauge by km containment use precision of 1e-6. + 2011-06-22 Sascha L. Teichmann <sascha.teichmann@intevation.de> * src/main/java/de/intevation/flys/model/River.java:
--- a/flys-backend/src/main/java/de/intevation/flys/model/River.java Wed Jun 22 08:56:09 2011 +0000 +++ b/flys-backend/src/main/java/de/intevation/flys/model/River.java Sun Jun 26 12:16:36 2011 +0000 @@ -3,6 +3,7 @@ import java.io.Serializable; import java.math.BigDecimal; +import java.math.MathContext; import javax.persistence.Entity; import javax.persistence.Id; @@ -27,6 +28,8 @@ public class River implements Serializable { + public static final MathContext PRECISION = new MathContext(6); + private Integer id; private String name; @@ -129,10 +132,10 @@ public Gauge determineGaugeByPosition(double p) { Session session = SessionHolder.HOLDER.get(); Query query = session.createQuery( - "from Gauge where river=:river " + - "and :p between range.a and range.b"); + "from Gauge g where river=:river " + + "and :p between g.range.a and g.range.b"); query.setParameter("river", this); - query.setParameter("p", new BigDecimal(p)); + query.setParameter("p", new BigDecimal(p, PRECISION)); List<Gauge> gauges = query.list(); return gauges.isEmpty() ? null : gauges.get(0); }