django增加数据库查询速度的多种办法
orm raw
使用orm .raw()方法可以通过原生语句查询数据库
orm select_related和prefetch_related
由于这个仍然是使用外键链接的,但是django使用这两个语句增加了外键查询的速度,简而言之就是通过改变迭代查询为链表查询,但是如果是使用链表查询的,我们也可以不使用外键的方法来进行数据库查询,就是我后面将会提到的原生语句查询。因为django的外键添加是非常容易出错的。
使用原生语句访问数据库的原因
很多人都说django orm原生语句查询性能并不如预期,查询了一下网上,orm查询慢的主要原因是因为他需要封装一次queryset,虽然在使用时候会比较方便,但是确实造成了查询速度慢的问题。这也就是为什么需要用原生语句访问数据库的原因
使用pymysql链接数据库
conn=pymysql.connect(host='localhost',user='用户名',password=‘密码',database='数据库名',charset='数据库编码格式')
cursor=conn.cursor(cursor=pymysql.cursors.DictCursor)
cursor.execute(原生mysql查询语句)
查询结果参数=cursor.fetchall()
可以将conn作为一个单例对象方便在整个项目中

本文介绍了多种提升Django数据库查询速度的方法,包括使用ORM的raw()、select_related和prefetch_related,阐述了使用原生SQL的原因,探讨了pymysql与Django内置db接口的使用,详细讲解了数据库视图的创建、查询和优缺点,并介绍了存储过程的创建、参数模式及其在链表查询中的应用。
最低0.47元/天 解锁文章

4831

被折叠的 条评论
为什么被折叠?



