我正在使用django-ajax-choose来方便Django admin中的用户输入;特别是在“通过”模型内联的多对多关系中:
class Part(models.Model):
item_code = models.CharField(max_length=100, primary_key=True)
name = models.CharField('Part Name', max_length=128)
def __unicode__(self):
return self.item_code
class Service(models.Model):
parts = models.ManyToManyField(Part, through='ServicePart')
class ServicePart(models.Model):
STATE_CHOICES = (
('N', 'New'),
('U', 'Used'),
)
service = models.ForeignKey(Service)
part = models.ForeignKey(Part)
cost = models.DecimalField ...
state = models.CharField(max_length=1, choices=STATE_CHOICES)
class ServicePartInline(AjaxSelectAdminTabularInline):
model = ServicePart
form = make_ajax_form(ServicePart, {
#item_code is a lookup channel
'part': 'item_code',
},
show_help_text=True)
extra = 2
class ServiceAdmin(admin.ModelAdmin):
inlines = [ServicePartInline,]
class PartLookup(LookupChannel):
model = Part
def get_query(self, q, request):
return Part.objects.filter(Q(item_code__icontains=q) | Q(name__istartswith=q)).order_by('name')
def get_result(self, obj):
return obj.name
def format_match(self, obj):
return u"%s<div><i>%s</i></dev>" % (escape(obj.item_code), escape(obj.name))
def format_item_desplay(self, obj):
return u"%s<div><i>%s</i></dev>" % (escape(obj.item_code), escape(obj.name))
AJAX_LOOKUP_CHANNELS = {
'item_code': ('appname.lookups', 'PartLookup'),
}
现在一切正常(在服务管理员中选择了很多部分),直到我点击保存;我得到以下异常:
appname.lookups.PartLookup对象位于0x7f28742e5fd0&gt;找不到对象:6965933
6965933是我在服务管理员中选择的部分的代码...
我不明白导致此异常的原因。
感谢您的帮助
答案 0 :(得分:0)
事实证明问题是由于Part模型没有自动id作为主键。 一旦我通过将数据库和修改后的item_code更改为唯一而不是主键来添加自动主键,问题就解决了。
在上述之后,您需要处理与Part模型有关系的模型,因为使用item_code而不是新添加的id引用了关系。