Django中update和save()同时作用

Posted ellisonzhang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django中update和save()同时作用相关的知识,希望对你有一定的参考价值。

save() 默认保存后会看到sql语句中更新了所有字段,而save的值是之前获取时候的字段值,是缓存下来的,并不一定最新,可能中途其他地方被更新过(在Django工程下的settings.py下将log设置为DEBUG,即可查看save和update分别执行了哪些SQL语句)

UPDATE pxb_sx2_test SET user_id = 335, catalog_id = 12558, level_id = 4, level_status = 0, position = 440, type = 2, add_time = ‘2016-09-14 17:44:07‘, update_time = ‘2016-09-14 17:53:17.077520‘ WHERE pxb_sx2_test.id = 175;

update 更新指定字段

UPDATE pxb_sx2_test SET position = 441 WHERE pxb_sx2_test.id = 175;

如果两个同时用,或者不同地方,但可能会同时更新的话会几率性出现更新了,但是数据库中值并没有改变。其实是update更新过后,正好save了过时的字段值,导致看起来没有更新。 django 1.5之后save可以加入参数只更新指定字段。

test.position = 441
test.save(update_fields=[‘position‘])

性能对比

  • 从SQL的执行情况来看,使用upate是要优于save方式的;
  • 从使用情境上看,update更加适用于批量数据更新,而save则更适合当然也只适合做单条记录的数据更新操作了。

以上是关于Django中update和save()同时作用的主要内容,如果未能解决你的问题,请参考以下文章

Django“bulk_save”和“bulk_update”

Django save方法的update_fields

django 一对多的添加记录create 和save 方法,update 更新和save()方法的区别,查询API的方法

Django模型操作常用方法

通过 .update() ORM 更新 Django ImageField

使用 Django 时,save() 函数在使用模型表单时不起作用