在我的 models.py 中,我有以下代码:
from __future__ import unicode_literals
from django.db import models
from django.contrib.postgres.fields import JSONField
import json
class Table(models.Model):
name = models.CharField(max_length=255)
structure = JSONField(default=json.dumps('{}'))
def __unicode__(self):
return self.name
class Column(models.Model):
table = models.ForeignKey(Table, related_name='columns')
name = models.CharField(max_length=255)
required = models.BooleanField(default=True)
def __unicode__(self):
return self.name + ' FROM TABLE ' + self.table.name
def save(self, *args, **kwargs):
if not self.pk:
self.table.structure[self.name] = {
'required' : self.required,
}
从代码中可以看出,当保存Column时,如果列的必填字段被添加到Table的结构中。但是,当我尝试从管理面板保存列时,出现以下错误:
TypeError at /admin/myapp/column/add/
'unicode' object does not support item assignment
我认为问题在于我的结构字段的默认值。我也尝试了以下内容:
structure = JSONField(default={})
structure = JSONField(default='{}')
structure = JSONField(default=dict)
每一次,我都有同样的错误。有帮助吗?感谢。
答案 0 :(得分:3)
根据文档,如果您希望默认为dict,则正确的定义为JSONField(default=dict)
。请注意,您可能需要清理现有数据库 - 作为unicode字符串存储的内容(使用您的原始定义)仍然会被反序列化为unicode字符串。
如果您为该字段指定默认值,请确保它是可调用的,例如dict (对于空的默认值)或返回dict的可调用对象(例如 功能)。错误地使用default = {}会创建一个可变的默认值 在JSONField的所有实例之间共享。
所以你可以先通过阅读文档来省去一些麻烦。
答案 1 :(得分:-1)
修改强>
只需保留默认值,因为它是空的。这已经是默认值了。您也可以使用None
作为默认值(请参阅this帖子)