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作为一个单例对象方便在整个项目中