首页 > 其他 > 详细

Django ORM queryset object 解释(子查询和join连表查询的结果)

时间:2019-02-13 20:19:07      阅读:916      评论:0      收藏:0      [点我收藏+]
#下面两种是基于QuerySet查询  也就是说SQL中用的jion连表的方式查询
books = models.UserInfo.objects.all()

print(type(books)) ---> <class ‘django.db.models.query.QuerySet‘> 查询出来是一个对象QuerySey

取值 print(books.values())



books = models.UserInfo.objects.filter()
print(type(books)) ---> <class ‘django.db.models.query.QuerySet‘> 查询出来一个QureySet

取值 print(books.values())
 
总结:books查询来了结果是queryset,然后在这个基础上面查询作者的名字,也就是跨表查询,这时候就需要用values去获取另外一个表的数据.
怎么获取呢? 就通过books.values("user__name") user是UserInfo表字段的名称 __代表双下划线




#基于对象的查询 也就是说SQL中用的子查询,就是slecte 里面套了slecte查询方式
books = models.UserInfo.objects.first()
print(type(books)) ---> <class ‘app.models.UserInfo‘> 查询出来是一个对象
取值 print(books.password)

总结:什么是基于对象? 就是说books对象已经拿到了,相当于就是表中的name这个对象已经查询到了,然后对象点属性取值就可以了
可以用点的方式获取数据 books.name 或者 book.age 等

Django ORM queryset object 解释(子查询和join连表查询的结果)

原文:https://www.cnblogs.com/ajaxa/p/10371680.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!