Django-使用GeoDjango存储用户位置数据

时间:2018-09-03 08:52:46

标签: django geodjango

我想使用GeoDjango从用户位置点信息中检索信息,例如城市,国家等。 为了使用GeoDjango,我必须安装PostGIS,它将为PostgreSQL添加地理对象支持。

问题:

  1. 我是否必须在默认数据库上安装PostGIS,还是将位置数据存储在其他数据库中的最佳实践?
  2. 我可以混合使用django.db.modelsdjango.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()

1 个答案:

答案 0 :(得分:2)

  1. 使用相同的数据库就可以了(并使事情变得容易得多。)
  2. 您可以将它们混合。与postgres contrib字段相同;您只需在需要的地方使用它们即可。

我知道您没有问这个问题,但是如果可能的话,它将简化为use a custom user model,而不是像您所说明的一对一扩展模型。