【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特地提供给我们的方便批量操作数据库的方式,效率非常高!!!
本文来自博客园,作者:Chimengmeng,转载请注明原文链接:https://www.cnblogs.com/dream-ze/p/18081750