我想使用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()
- 同一个数据库很好(并且使事情变得容易得多。
- 你可以混合它们。与 postgres contrib 字段相同;您只需在需要的地方使用它们。
我知道你没有问这个,但如果可能的话,使用自定义用户模型而不是像你说明的那样一对一的扩展模型会简化事情。