在我的项目中,我使用PostgreSQL / PostGIS作为数据库,并使用配置了django.contrib.gis的Django。现有表pois包含地理空间点数据。以下是SQL create语句的摘录:

CREATE TABLE pois
(
  ogc_fid serial NOT NULL,
  the_geom geometry(Point,900914),
  name character varying(254),
  -- ...


我使用以下命令生成了Django模型:

$ python manage.py inspectdb


生成的模型如下所示:

from django.contrib.gis.db import models

class POIs(models.Model):
    ogc_fid = models.AutoField(primary_key=True)
    the_geom = models.TextField(blank=True, null=True) # This field type is a guess.
    name = models.CharField(max_length=254, blank=True, null=True)

    class Meta:
        managed = False
        db_table = 'pois'


我添加以下字段以使用特定于Ge​​oDjango的实例覆盖默认管理:

objects = models.GeoManager()


现在,我想用正确的数据类型替换the_geom = models.TextField(),该数据类型应为models.PointField()models.GeometryField()。我都尝试过。然后,我在Python Shell上测试模型:

$ python manage.py shell
Python 3.4.3 (default, Jul 28 2015, 18:20:59)
In [1]: from berlin import models
In [2]: models.POIs.objects.first()


这将失败,并输出以下堆栈跟踪:

/home/user/.virtualenvs/myproject/lib/python3.4/site-packages/django/contrib/ \
    gis/db/models/fields.py in select_format(self, compiler, sql, params)
     57         else:
     58             sel_fmt = '%s'
---> 59         if connection.ops.select:
     60             # This allows operations to be done on fields in the SELECT,
     61             # overriding their values -- used by the Oracle and MySQL

AttributeError: 'DatabaseOperations' object has no attribute 'select'


当我将模型保留为models.TextField时没有错误。然后输出字符串值。

最佳答案

settings.py中的数据库配置不正确:



DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'geodjango',
        'USER': 'geo',
        'PASSWORD': 'secret',
        'HOST': 'localhost',
        'PORT': '5432',
    }
}


正确:

DATABASES = {
    'default': {
        'ENGINE': 'django.contrib.gis.db.backends.postgis', # Here
        'NAME': 'geodjango',
        'USER': 'geo',
        'PASSWORD': 'secret',
        'HOST': 'localhost',
        'PORT': '5432',
    }
}


我已经以某种方式在the documentation中对此进行了监督。感谢#django irc频道的apollo13提供了正确方向的建议。

10-05 23:01
查看更多