如何解决Django中save方法导致的错误问题?
- 内容介绍
- 文章标签
- 相关推荐
本文共计664个文字,预计阅读时间需要3分钟。
在最新项目中,频繁出现资产任务状态问题。查看日志、分析代码逻辑,暂时未发现具体错误。可能是某段时间内某个字段未更新,令人困惑。初期感觉似乎是没有问题。
最近项目中的资产的任务状态频频出现问题,查看日志文件,看代码逻辑,也没发现什么具体的错误,总是过段时间就会出现一个表的字段没有更新的问题,很头疼。
开始时,觉得是没有添加事务,所以同时更新两个不同的表,其中一个表的内容没有写进去;加了事务后,又出现这种问题。
后来看代码,发现有两个线程在同一时间先后修改同一个表,问题来了,django的save()会更新所有的字段。
举个例子,我有两个线程分别修改User表,thread1修改User表的name字段,thread2修改User表的email字段。
在同一个时间,这两个线程获取了相同的User实例, 这个时候同一个实例有两份缓存,thread1修改了name字段,email字段不变;
thread2修改了email字段,name字段不变,这样出来的结果不是我们所设想的那样,name和email字段都会改变,实际上改变的只有email字段,name字段被thread2线程又写回来了。
解决办法:
save()函数加一个update_fields参数就好了。
本文共计664个文字,预计阅读时间需要3分钟。
在最新项目中,频繁出现资产任务状态问题。查看日志、分析代码逻辑,暂时未发现具体错误。可能是某段时间内某个字段未更新,令人困惑。初期感觉似乎是没有问题。
最近项目中的资产的任务状态频频出现问题,查看日志文件,看代码逻辑,也没发现什么具体的错误,总是过段时间就会出现一个表的字段没有更新的问题,很头疼。
开始时,觉得是没有添加事务,所以同时更新两个不同的表,其中一个表的内容没有写进去;加了事务后,又出现这种问题。
后来看代码,发现有两个线程在同一时间先后修改同一个表,问题来了,django的save()会更新所有的字段。
举个例子,我有两个线程分别修改User表,thread1修改User表的name字段,thread2修改User表的email字段。
在同一个时间,这两个线程获取了相同的User实例, 这个时候同一个实例有两份缓存,thread1修改了name字段,email字段不变;
thread2修改了email字段,name字段不变,这样出来的结果不是我们所设想的那样,name和email字段都会改变,实际上改变的只有email字段,name字段被thread2线程又写回来了。
解决办法:
save()函数加一个update_fields参数就好了。

