【18.0】Django框架之批量插入数据

【一】引入

  • 项目需求:
    • 浏览器中访问django后端某一条
  • url(如:127.0.0.1:8080/index/)
    • 实时朝数据库中生成一千条数据并将生成的数据查询出来
    • 并展示到前端页面

【二】创建模型表

class Book(models.Model):
    title = models.CharField(max_length=32)

【三】单条插入数据

【1】后端

def get_book(request):
    # (1)先给Book表插入一万条数据
    for i in range(1000):
        models.Book.objects.create(title=f'第{i}本书')
    # (2)将所有数据查询到并展示给前端页面
    book_queryset = models.Book.objects.all()
		# (3)将查询出来的数据传递给html页面
    return render(request, 'books.html', locals())

【2】前端

{% for book_obj in book_queryset %}
    <p>{{ book_obj.title }}</p>
{% endfor %}
  • 上述代码书写完毕后启动django后端
  • 浏览器访问,会发现浏览器会有一个明显的卡顿等待时间
  • 这不是你的浏览器有问题也不是网速有问题
  • 而是后端再不停的操作数据库,耗时较长,大概需要等待一段时间之后才能正常看到刚刚插入的1000条数据
  • 很明显这样操作数据库的效率太低
  • 那有没有一种方式是专门用来批量操作数据库的呢?答案是肯定的!

【三】批量插入数据

  • 当我们想向数据库批量插入数据的时候,使用ORM提供的bulk_create方法能够大大的减少操作的时间
def get_book_bulk(request):

    # 批量插入
    boo_list = []
    for i in range(1000):
        book_obj = models.Book.objects.create(title=f'第{i}本书')
        boo_list.append(book_obj)
    # 批量插入数据
    models.Book.objects.bulk_create(boo_list)
    return render(request, 'books.html', locals())
  • 代码修改完毕之后其他地方无需改动,重启django项目浏览器重新访问
  • 你会立马发现数据量增大十倍的情况下页面出现的速度居然还比上面的版本要快上速度倍!!!
  • bulk_create方法是django orm特地提供给我们的方便批量操作数据库的方式,效率非常高!!!
  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值