目的是更新数据库里已经存在的值
先是用了直接赋值
re_rating = Rating.objects.get(user_id=user_id, movie_id=movie_id)
re_rating.movie_rating = movie_rating
但是数据库直接新创建了一条记录,这条路行不通了,接着查了官方文档用了update,结果报错
Rating.objects.get(user_id=user_id, movie_id=movie_id).update(movie_rating=movie_rating)
#####报错
AttributeError: 'Rating' object has no attribute 'update'
试着输出了一下get
和fileter
的结果
print("get:",Rating.objects.get(user_id=user_id, movie_id=movie_id))
print("filter:", Rating.objects.filter(user_id=user_id, movie_id=movie_id))
re_rating 5.0
get: Rating object (100837)
filter: <QuerySet [<Rating: Rating object (100837)>]>
没想明白为什么,但知道了update只能结合filter一起用,代码改成下图就通过了。
Rating.objects.filter(user_id=user_id, movie_id=movie_id).update(movie_rating=movie_rating)