Django 查询

Q查询

# 1.引入包
from django.db.models import Q
语法: Q(字段名_运算符=)Q()|Q()q()&Q()
#2.查询语句使用即可
ischeck = '1'
name = '123'
querylist = Member.objects.filter(Q(ischecklm=ischeck) & (Q(name=name) | Q(phone=name))).exclude(talent_id="")

正常查询

# 查询包含'部'的图书
BookInfo.objects.filter(name_contains = '部')

#  查询书名以'部'结尾的图书
BookInfo.objects.filter(name_endswith = '部')

#  查询编号以'1,3,5'的图书
BookInfo.objects.filter(id_in= [1,3,5])

#  查询编号大于'3'的图书,gt 大于  gte 大于等于  lt小于 lte小于等于
BookInfo.objects.filter(id_gt= 3)

#  查询编号不等于'3'的图书
BookInfo.objects.filter(id_exact= 3)


F操作

F对象的语法形式,两个属性间的比较
filter(字段名—运算符=F('字段名'))
# 查询阅读量大于等于评论量的图书
from django.db.models import F
BookInfo.objects.filter(readcount_get=F('commentcount'))

一对多查询

# 书籍与人   1:n
# 书籍中没有关于人物的字段,人物中有关于 book 外键
# 语法 主表模型.关联模型类名小写_set
class peopleinfo(models.Model):
	'''
	book = models.ForeignKey(BookInfo,on_delete=models.CSSCADE,verbose_name='外键')
	'''

# 查询书籍为1的所有人物信息
book = BookInfo.objects.get(id=1)
book.peopleinfo_set.all() #获取所有信息

# 查询人物为1的书籍信息
person = PeopkeInfo,objects.get(id=1)
person.book    #实例对象

聚合函数

# 语法形式:aggregate(Xxx('字段'))
from django.db.models import Sum,Avg,Max,Min,Count
BookInfo.objects.aggregate(Sum(''))
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值