一、第一步,导入bulk_update包
from bulk_update.helper import bulk_update
二、写一个类
class CommonQuerySet(models.QuerySet):
def bulk_update(self, objs, update_fields=None,
exclude_fields=None, batch_size=None):
self._for_write = True
using = self.db
return bulk_update(
objs, update_fields=update_fields,
exclude_fields=exclude_fields, using=using,
batch_size=batch_size)
三、第三步,在需要使用批量更新的model类中,添加一行代码
1 2 3 4 5 6 | class Track(models.Model): album = models.ForeignKey(Album, related_name = 'tracks' , on_delete = models.CASCADE) order = models.IntegerField() title = models.CharField(max_length = 100 ) duration = models.IntegerField() objects = CommonQuerySet.as_manager() <br> <br><br> class Meta: <br> unique_together = ( 'album' , 'order' ) ordering = [ 'order' ] |
方法二:
第一步导入包
from django_bulk_update.helper import bulk_update
第二步使用
prescription_item_objs = [] for prescription_item_list in prescription_item_data: for i in prescription_item_list: prescription_dic[i.get('id')] = i.get('weight') for i in prescription_item_qs: i.weight = prescription_dic.get(i.id) prescription_item_objs.append(i) print(prescription_item_objs) bulk_update( prescription_item_objs, update_fields=['weight',] )
分类:
杂七杂八
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」