Django批量删除和添加多对多关系

2024-09-30 18:13:02 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个问题批量多对多关系删除和添加。在

这是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"
})

数据是这样打包的

^{pr2}$

这就是与技能相关的模型

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,但我遵守了文件


Tags: jsontruedata关系models技能bodynull
1条回答
网友
1楼 · 发布于 2024-09-30 18:13:02

您应该改用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)

丹戈docs。在

相关问题 更多 >