我想使用GeoDjango从用户位置点信息中检索,如城市,国家等。为了使用GeoDjango,我必须安装PostGIS
,它为PostgreSQL添加了地理对象支持。
问题:
PostGIS
,或者是将位置数据存储在不同数据库中的最佳做法?django.db.models
和django.contrib.gis.db.models
来明确区分GeoDjango字段和默认字段吗?例:
from django.db import models
from django.contrib.gis.db import models as geo_models
class Profile(models.Model):
"""
This model extends the `User` model as an One-To-One link.
"""
user = models.OneToOneField(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
birth_date = models.DateField(null=True, blank=True)
company_name = models.CharField(max_length=100, blank=True)
location = geo_models.PointField()
而且我知道你没有问这个问题,但如果可能的话,它会简化use a custom user model的内容,而不是像你所说明的一对一扩展模型。