我有一個批量問題與多對多的關係刪除和添加。django批量刪除並添加多對多關係
這是發送要更新的用戶的pk和將被添加到多對多的技能的pk的JS。
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'對象沒有屬性'技能集' 雖然我不確定爲什麼?也許我錯誤地製造了M2M,但我遵循了文檔
一般來說,你應該在語句末尾加上分號 – thanksd