Естественный ключ Django для светильников дает ошибку десериализации
Я видел несколько подобных вопросов на SO, но ни один из них не отвечает на мою конкретную проблему. Я новичок в Django и руководствовался инструкциями на этой странице, чтобы позволить себе использовать естественные ключи для загрузки приборов. Тем не менее, я получаю ошибки десериализации, потому что Django хочет целое число для внешнего ключа и не может отобразить мой естественный ключ на целочисленный первичный ключ, как указано в инструкциях. В частности, мой соответствующий код модели:
class GraphTypeManager(models.Manager):
def get_by_natural_key(self, type):
return self.get(type=type)
class GraphType(models.Model):
type = models.CharField(max_length=100, unique=True)
class GraphManager(models.Manager):
def get_by_natural_key(self, name):
return self.get(name=name)
class Graph(models.Model):
name = models.CharField(max_length=200, unique=True)
type = models.ForeignKey(GraphType)
class LineManager(models.Manager):
def get_by_natural_key(self, name):
return self.get(name=name)
class Line(models.Model):
name = models.CharField(max_length=200, unique=True)
class GraphToLineManager(models.Manager):
def get_by_natural_key(self, line, graph):
return self.get(line=line,graph=graph)
class GraphToLine(models.Model):
line = models.ForeignKey(Line)
graph = models.ForeignKey(Graph)
class Meta:
unique_together = (('line', "graph"),)
И мой прибор YAML:
- model: graphs_container.GraphType
pk: null
fields:
type: TimeSeries
- model: graphs_container.Graph
pk: null
fields:
name: LikesOverTime
type: [TimeSeries]
- model: graphs_container.Graph
pk: null
fields:
name: UsersOverTime
type: [TimeSeries]
- model: graphs_container.Line
pk: null
fields:
name: NumUsers
- model: graphs_container.Line
pk: null
fields:
name: NumLikes
Но при попытке запустить python manage.py loaddata sample_data.yaml
Я получаю следующую ошибку:
DeserializationError: [u"'['TimeSeries']' value must be an integer."]
Что я делаю неправильно?
1 ответ
Решение
Вам нужно
- определять
natural_key
метод в ваших моделях - есть менеджер с
get_by_natural_key
метод - собственно прикрепить менеджеров (
objects=GraphManager()
)
Поиграв с вашим кодом, я заставил его работать:
class GraphTypeManager(models.Manager):
def get_by_natural_key(self, type):
return self.get(type=type)
class GraphType(models.Model):
type = models.CharField(max_length=100, unique=True)
objects = GraphTypeManager()
def natural_key(self):
return (self.type,) # must return a tuple
class GraphManager(models.Manager):
def get_by_natural_key(self, name):
return self.get(name=name)
class Graph(models.Model):
name = models.CharField(max_length=200, unique=True)
type = models.ForeignKey(GraphType)
objects = GraphManager()
Сброс данных:
$ bin/django dumpdata index --indent=4 --natural > project/apps/fixtures_dev/initial_data.json
[
{
"pk": 1,
"model": "index.graphtype",
"fields": {
"type": "asotuh"
}
},
{
"pk": 1,
"model": "index.graph",
"fields": {
"type": [
"asotuh"
],
"name": "saoneuht"
}
}
]
bin/django loaddata project/apps/fixtures_dev/initial_data.json
Installed 2 object(s) from 1 fixture(s)