Django07-批量创建数据

Posted dxnui119

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django07-批量创建数据相关的知识,希望对你有一定的参考价值。

通过views.py文件中创建

第1种方法
循环创建数据, 这种方法不推荐,因为每一次循环都会连接一次数据库,效率较慢

def user_list(request):
    user_all = models.User.objects.all()
    for i in range(302):
        models.User.objects.create(username=user-%s%(i))
    return render(request, user/user_list.html, {user_all: user_all})        

 

第2种方法
先创建一个空列表,将循环的对象加入到空列表中,再一次性在数据库中创建,效率高

要使用bulk_create方法进行批量创建

def user_list(request):
    user_all = models.User.objects.all()
        user_list = []
        for i in range(302):
             obj = models.User(username=user-%s%(i),pwd=123,gender=0, depart=models.Depart.objects.filter(pk=1).first())
             user_list.append(obj)
        models.User.objects.bulk_create(user_list, batch_size=100)   #batch_size可以理解为批处理参数,控制每一次批量添加数据的数量
    return render(request, user/user_list.html, {user_all: user_all})

也可以使用列表解析替代for循环会更快

user_list = [models.User(username=user-%s%(i),pwd=123,gender=0, depart=models.Depart.objects.filter(pk=1).first()) for i in range(302)]
models.User.objects.bulk_create(user_list, batch_size=100)    

 

第3种方法
批量导入时数据重复的解决方法

如果导入数据过多,导入时出错了,或者你手动停止了,导入了一部分,还有一部分没有导入。或者你再次运行上面的命令,你会发现数据重复了,怎么办呢?
django.db.models中还有一个函数叫get_or_create(),有就获取过来,没有就创建,用它可以避免重复,但是速度可以会慢些,因为要先尝试获取,看看有没有

只要把bulk_create换成get_or_create就不会重复导入数据了

models.User.objects.get_or_create(user_list, batch_size=100) 

返回值是(BlogObject, True/False)新建时返回 True, 已经存在时返回 False。

 

以上是关于Django07-批量创建数据的主要内容,如果未能解决你的问题,请参考以下文章

Django - 高效地批量创建继承模型

Django 批处理/批量更新或创建?

django批量创建忽略重复项[重复]

Django 2021年最新版教程22数据库model 批量插入创建

Django在批量插入/更新/删除时“模拟”数据库触发行为

JavaScript 片段在 Django 模板中不起作用