Django - Храните данные о местоположении пользователя с GeoDjango - PullRequest
0 голосов
/ 03 сентября 2018

Я хочу использовать GeoDjango для получения информации о точках местоположения пользователя, таких как город, страна и т. Д. Чтобы использовать GeoDjango, мне нужно установить PostGIS, который добавляет поддержку географических объектов в PostgreSQL.

Вопросы:

  1. Нужно ли устанавливать PostGIS в базе данных по умолчанию или лучше хранить данные о местоположении в другой базе данных?
  2. Могу ли я смешать 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()

1 Ответ

0 голосов
/ 03 сентября 2018
  1. Та же база данных хороша (и делает вещи намного проще.)
  2. Вы можете смешать их. То же самое с полями Postgres contrib; вы просто используете их там, где вам нужно.

И я знаю, что вы не спрашивали об этом, но, если возможно, это упростит вещи до использования пользовательской модели вместо модели расширения «один к одному», как вы иллюстрировали.

...