django bulk_create批量插入数据
原创 我只是个小QA 发布于2018-09-26 15:20:18 阅读数 3257 收藏 更新于2018-09-26 15:20:18 分类专栏: django 展开需求:手动写操作日志存库,每次都需要访问一次数据库,性能较差,改为先存到缓存文件,特定条件触发/定时写入数据库,
在django1.4以后加入了新的特性。使用django.db.models.query.QuerySet.bulk_create()批量创建对象,减少SQL查询次数。改进如下:
add_record_list=[]
f=utils.open_txt(cache_file_name)
for line in f.readlines():
record_line = json.loads(line)
#创建一个对象
obj =record(
user_name=record_line['user_name'],#操作人
operate_old_record=record_line['old_content'],#具体操作的内容(旧)
operate_now_record=record_line['new_content'],#具体操作的内容(新)
)
add_record_list.append(obj)
#批量写入数据
record.objects.bulk_create(add_record_list)
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
其中record是模型对象,替换为对应即可。
record.objects.bulk_create(add_record_list)
- 1