Opened 16 years ago
Closed 15 years ago
#11168 closed (invalid)
postgis geometry alternatively seen as linestring then multilinestring
Reported by: | anonymous | Owned by: | nobody |
---|---|---|---|
Component: | GIS | Version: | 1.0 |
Severity: | Keywords: | GEOS API, Postgis | |
Cc: | Triage Stage: | Design decision needed | |
Has patch: | no | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
Django 1.0.2 final on MacOS 10.5 python 2.5
GEOS Framework 3.0.1-1
see django shell example below
RegionHydro is a GeometryField from a postgis table containing linestrings and multilinestrings
>>> r=RegionHydro.objects.get(id=19) >>> c=r.getCoursDo() >>> c [<CoursDo: La Meuse>, <CoursDo: Canal de l'Est Branche-Nord>] >>> c[1].geom <MultiLineString object at 0x28208c4> >>> c[1].geom <LineString object at 0x28209b4> >>> c[1].geom <MultiLineString object at 0x28208c4> >>> c[1].geom <LineString object at 0x28209b4>
Change History (6)
comment:1 by , 16 years ago
comment:2 by , 15 years ago
Please provide the geometry data (in WKT format) so I can attempt to reproduce.
follow-up: 6 comment:3 by , 15 years ago
I solved the problem by forcing all the linestrings to multilinestrings in the postgis table and setting the field type to MultiLineString in django.
I'm not sure the problem comes from the geometry itself but may be from the type of the data table in postgis (GEOMETRY).
You could eventually download the data here: http://services.sandre.eaufrance.fr/data/zonage/Hydrographie2008/arcinfo/FranceEntiere/courdo00.e00.zip
and import it to postgis using ogr:
set PGCLIENTENCODING=LATIN1 ogr2ogr -f PostgreSQL "PG:dbname=eau_france user=postgres password=postgres" -nlt GEOMETRY cours_d_eau.shp
(you have to force type geometry)
then see if you can reproduce the thing
this was my model definition for this feature:
class CoursDo(models.Model): id = models.IntegerField(db_column="ogc_fid", primary_key=True) toponyme = models.CharField(db_column="toponyme", max_length=127) codehydro = models.CharField(db_column="code_hydrographique", max_length=8) classification = models.CharField(db_column="classification", max_length=1) geom = models.GeometryField(db_column="wkb_geometry", srid=32767) objects = models.GeoManager() class Meta: db_table = "cours_d_eau" verbose_name_plural = r"Cours d'eau" verbose_name = r"Cours d'eau" def __unicode__(self): return self.toponyme.strip()
comment:4 by , 15 years ago
Triage Stage: | Unreviewed → Accepted |
---|
comment:5 by , 15 years ago
Triage Stage: | Accepted → Design decision needed |
---|
comment:6 by , 15 years ago
Resolution: | → invalid |
---|---|
Status: | new → closed |
Replying to ludifan:
I solved the problem by forcing all the linestrings to multilinestrings in the postgis table and setting the field type to MultiLineString in django.
I'm not sure the problem comes from the geometry itself but may be from the type of the data table in postgis (GEOMETRY).
You could eventually download the data here: http://services.sandre.eaufrance.fr/data/zonage/Hydrographie2008/arcinfo/FranceEntiere/courdo00.e00.zip
and import it to postgis using ogr:
set PGCLIENTENCODING=LATIN1 ogr2ogr -f PostgreSQL "PG:dbname=eau_france user=postgres password=postgres" -nlt GEOMETRY cours_d_eau.shp(you have to force type geometry)
The data link is for ArcInfo E00 format, I found the shapefile data here: http://services.sandre.eaufrance.fr/data/zonage/Hydrographie2009/arcgis/FranceEntiere/cours_d_eau.shp.zip. I loaded it up, and it's a larger dataset (> 125K rows).
I don't think there's a bug here. Specifically, I don't think you're ordering your QuerySet
, and what you think is the same model is actually a different one -- in other words, you're seeing a different geometry on a separate record. Each time you're evaluating c[1].geom
you're hitting the database, and if you're not ordering your SQL there's no guarantee it'll return the same record each time. See Ordering Data from the Django Book.
If you can boil it down to a distinct, reproducible test case I'll be glad to reopen the ticket -- otherwise, I'm closing as invalid.
sorry,
I meant : CoursDo model geom attribute is a GeometryField from a postgis table containing linestrings and multilinestrings
to make it simple, I have a multilinestring object that is alternatively seen as a linestring then a multilinestring by the GEOS API
hope it's clear enough...