1

我正在使用 django-ajax-selects 来方便用户在 Django admin 中输入;特别是在“通过”模型内联的多对多关系中:

模型.py

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)

管理员.py

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,]

查找.py

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))

设置.py

AJAX_LOOKUP_CHANNELS = {
    'item_code': ('appname.lookups', 'PartLookup'),
}

现在一切正常(在服务管理员中选择许多部分),直到我点击保存;我得到以下异常:

appname.lookups.PartLookup 对象位于 0x7f28742e5fd0> 找不到对象:6965933

6965933 是我在服务管理员中选择的部分的代码...

我不明白是什么导致了这个异常。

感谢您的帮助

4

1 回答 1

0

原来问题是由于零件模型没有自动 id 作为主键引起的。一旦我通过更改数据库添加自动主键并将 item_code 修改为唯一而不是主键,问题就解决了。

在上述之后,您需要注意与 Part 模型有关系的模型,因为该关系是使用 item_code 而不是新添加的 id 引用的。

于 2013-12-03T15:08:54.060 回答