django批量删除并添加许多关系

时间:2015-12-14 18:54:01

标签: javascript python ajax django

我遇到了批量删除和添加多对多关系的问题。

这是JS发送要更新的用户的pk以及将被添加到多对多的技能的pk。

function attachskillls(){

var checkedValues = $('input:checkbox:checked').map(function() {
  return this.value;
}).get();

console.log(checkedValues)

data = {
  'skills' : checkedValues,
  'pk' : getUrlVars()["id"]
}
console.log(data)

$.ajax({
  type: "POST",
  url: "/api/skill/attch/",
  data: JSON.stringify(data),
  contentType: "application/json",
  dataType: "json"
})

数据打包就像这样

{"skills":["1","2","3"],"pk":"1"}

这是与技能相关的模型

class Resource(models.Model):

    title = models.CharField(max_length=10)
    preferred_name = models.CharField(max_length=20)
    last_name = models.CharField(max_length=30)
    employstatus = models.CharField(max_length=20)
    employer = models.ForeignKey('Employer')
    role = models.ForeignKey('Role')
    location = models.ForeignKey('Location')
    workphone = models.CharField(max_length=25, blank=True, null=True)
    mobile_phone = models.CharField(max_length=15, blank=True, null=True)
    email = models.CharField(max_length=15, blank=True, null=True)
    notes = models.CharField(max_length=200, blank=True, null=True)
    updated_by = models.CharField(max_length=30, blank=True, null=True)
    skillset = models.ManyToManyField('ReferenceSkillList')

这是我的api到目前为止我试图通过pk过滤资源,所以我有正确的用户添加技能,然后清除可能已经添加的所有关系然后批量添加新的关系。

def Skillattachment(request):
    body = json.loads(request.body)
    if request.method == "POST":
        pk = body['pk']
        skills = body
        res = Resource.objects.filter(pk=pk)
        res.skillset.clear()
        res.skillset.add(skills)

    else:
        search_id = ''

    return HttpResponse(json.dumps(body), content_type='application/json')

有没有更好的方法来做我正在尝试的东西?

我目前收到错误 'QuerySet'对象没有属性'skillset' 虽然我不确定为什么?也许我已经错误地制作了M2M,但我已经按照文档

1 个答案:

答案 0 :(得分:1)

您应该使用res = Resource.objects.get(pk=pk)代替。 filter会为您提供一个查询集。

此外,您的变量skills只是一个数据结构而不是对象。您可能需要:

skills = ReferenceSkillList.objects.filter(id__in=body['skills'])
res = Resource.objects.get(pk=pk)
res.skillset.clear()
res.skillset.add(*skills)

Django docs