我遇到了批量删除和添加多对多关系的问题。
这是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,但我已经按照文档
了答案 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。