温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

使用Django怎么批量插入数据

发布时间:2021-05-21 17:54:57 来源:亿速云 阅读:281 作者:Leah 栏目:开发技术

这篇文章将为大家详细讲解有关使用Django怎么批量插入数据,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

views.py

from django.shortcuts import render, HttpResponse, redirect from app01 import models def get_book(request):   # for循环插入1000条数据   for i in range(1000):     models.Book.objects.create(name='第%s本书'%i)   book_queryset = models.Book.objects.all()   # 将插入的数据再查询出来   return render(request,'get_book.html',locals()) # 将查询出来的数据传递给html页面

urls.py

from django.conf.urls import url from app01 import views urlpatterns = [  url(r'^get_book/',views.get_book) ]

models.py

from django.db import models class get_book(models.Model):  title = models.CharField(max_length=64)

get_book.html

<!DOCTYPE html> <html lang="en"> <head>   <meta charset="UTF-8">   <title>Title</title>   <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>   {% load static %}   <link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}" rel="external nofollow" >   <link rel="stylesheet" href="{% static 'dist/sweetalert.css' %}" rel="external nofollow" >   <script src="{% static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script>   <script src="{% static 'dist/sweetalert.min.js' %}"></script> </head> <body> {% for book_obj in book_queryset %}    <p>{{ book_obj.title }}</p> {% endfor %} </body> </html>

上述代码书写完毕后启动django后端,浏览器访问,会发现浏览器会有一个明显的卡顿等待时间,这是因为后端在不停的操作数据库,耗时较长,大概需要等待一段时间之后才能正常看到刚刚插入的1000条数据,很明显这样操作数据库的效率太低,那有没有一种方式是专门用来批量操作数据库的呢?答案是肯定的!

bulk_create方法

将views.py中原先的视图函数稍作变化

def get_book(request):   l = []   for i in range(10000):     l.append(models.Book(title='第%s本书'%i))   models.Book.objects.bulk_create(l) # 批量插入数据     return render(request,'get_book.html',locals())

关于使用Django怎么批量插入数据就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI