一、QuerySet的概念
这一节中,学习如何通过Django的Model操作数据库。
我们同数据库的所有查询以及更新交互都是通过QuerySet来完成的
Django算是标准的MVC架构,虽然因为他的模板和View的概念,被大家戏称“MTV”,但是道理是一样的
Model作为MVC模式的基础层,也被称为数据层,负责为整个系统提供数据。因此,我们需要先理解一下他是如何提供数据的
Django通过给Model增加一个objects属性来提供数据操作的接口。比如想要查询所有文章的数据,Post.objects.all() all是一个方法代表所有信息,这样就能拿到,QuerySet对象,这个对象中包含了我们需要的数据,当我们用到它时,它才会去DB中获取数据,而不是执行Post.objects.all() 时去执行数据库查询语句,因为,QuerySet支持链式操作,如果每次都执行查询会存在性能问题
例如:
posts = Post.objects.all()
available_posts = posts.filter(status=1)
如果这条语句立即执行,先执行Post.objects.all()在执行posts.filter(status=1)这样就会产生两次数据库请求,两次查询存在重复查询,因此Django中的QuerySet本质上是一个懒加载的对象
posts = Post.objects.all() # 返回一个QuerySet对象并赋值给posts
available_posts = posts.filter(status=1) # 继续返回一个QuerySet对象,并赋值给available_posts
print(available_posts)
# 此时会根据上面的两个条件执行数据查询操作、对应SQL语句:
# SELECT * FROM bolg_post where status = 1
链式调用:
执行一个对象中的方法后,得到的结果还是这个对象,这样可以接着执行对象上的其他方法。例如:
posts = Post.objects.filter(status=1).filter(category=2).filter(title__icontains="carson")
在每一个函数或方法执行结果上可以继续调用同样的方法,因为每一个函数的返回值都是QuerySet
想想一下,把数据比作水,而方法就是管道,把不同的管道连起来形成“链”然后让数据流过去。
(下一节QuerySet的接口)