Django QuerySet的概念及使用

一、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的接口)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值