Django之ORM对象方法,聚合、分组、F、Q查询

对象的方法

<1> all():                 查询所有结果
 
<2> filter(**kwargs):      它包含了与所给筛选条件相匹配的对象,不存在返回一个空的QuerySet
 
<3> get(**kwargs):         返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。
 
<4> exclude(**kwargs):     它返回不符合筛选条件的对象
 
<5> values(*field):        返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列
 
<6> values_list(*field):   它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列
 
<7> order_by(*field):      对查询结果排序
 
<8> reverse():             对查询结果反向排序,请注意reverse()通常只能在具有已定义顺序的QuerySet上调用(在model类的Meta中指定ordering或调用order_by()方法)。
 
<9> distinct():            从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。此时可以使用distinct(),注意只有在PostgreSQL中支持按字段去重。)
 
<10> count():              返回数据库中匹配查询(QuerySet)的对象数量。
 
<11> first():              返回第一条记录
 
<12> last():               返回最后一条记录
 
<13> exists():             如果QuerySet包含数据,就返回True,否则返回False

单表查询双下划綫

models.Tb1.objects.filter(id__lt=10, id__gt=1)   # 获取id大于1 且 小于10的值
 
models.Tb1.objects.filter(id__in=[11, 22, 33])   # 获取id等于11、22、33的数据
models.Tb1.objects.exclude(id__in=[11, 22, 33])  # not in
 
models.Tb1.objects.filter(name__contains="ven")  # 获取name字段包含"ven"的
models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
 
models.Tb1.objects.filter(id__range=[1, 3])      # id范围是1到3的,等价于SQL的bettwen and

ForeignKey操作

class Publisher(models.Model):
    id = models.AutoField(primary_key=True)
    name = models.CharField(max_length=32, unique=True)

    def __str__(self):
        return "我是一个出版社对象:{}".format(self.name)


class Book(models.Model):
    id = models.AutoField(primary_key=True)
    price = models.DecimalField(max_digits=5, decimal_places=2, default=99.99)
    # 库存数
    kucun = models.IntegerField(default=1000)
    # 卖出数
    maichu = models.IntegerField(default=0)
    title = models.CharField(max_length=32)
    # 外键
    # related_name="books" 反向查询是用来代替 book_set的
    publisher = models.ForeignKey(
        to="Publisher",
        on_delete=models.CASCADE,
        related_name="books",
        related_query_name="xxoo",
        null=True
    )

    def __str__(self):
        return self.title

class Author(models.Model):
    id = models.AutoField(primary_key=True)
    name = models.CharField(max_length=32)
    books = models.ManyToManyField(to="Book")

    def __str__(self):
        return self.name
正向查找
对象查找	对象.关联字段.字段
book_obj = models.Book.objects.first()  # 第一本书对象
print(book_obj.publisher)  # 得到这本书关联的出版社对象
print(book_obj.publisher.name)  # 得到出版社对象的名称

修改
book_obj = models.Book.objects.get(id=9)
book_obj.title=request.POST.get("title")
book_obj.publisher_id=9
book_obj.save()

字段查找	关联字段__字段
书里面的publisher字段
print(models.Book.objects.values_list("publisher__name"))

反向查找
对象查找	obj.表名_set
# related_name="books" 反向查询是用来代替 book_set的
publisher = models.ForeignKey(
    to="Publisher",
    on_delete=models.CASCADE,
    related_name="books",
    related_query_name="xxoo",
    null=True
)
1. 基于对象查询 
publisher_obj = models.Publisher.objects.first()  # 找到第一个出版社对象
books = publisher_obj.book_set.all()  # 找到第一个出版社出版的所有书
books = publisher_obj.books.all()  # 找到第一个出版社出版的所有书
2. 基于双下划线
titles = models.Publisher.objects.values_list("book__title")
titles = models.Publisher.objects.filter(id=1).values_list("xxoo__title")
print(ret)

ManyToManyField方法

create()
创建一个新的对象,保存对象,并将它添加到关联对象集之中,返回新创建的对象。
models.Author.objects.first().book_set.create(title="番茄物语")

add()	把指定的model对象添加到关联对象集中。
book_obj = model.Book.objects.get(id=1)
models.Author.objects.first().add(book_obj)
models.Author.objects.first().add(1)

author_objs = models.Author.objects.filter(id__lt=3)
models.Book.objects.first().authors.add(*author_objs)

set()更新model对象的关联对象。
book_obj = models.Book.objects.first()
book_obj.authors.set([2, 3])

remove()	从关联对象集中移除执行的model对象
book_obj = models.Book.objects.first()
author_obj.remove(book_obj)
author_obj.remove(1)

clear()从关联对象集中移除一切对象。
book_obj = models.Book.objects.first()
book_obj.authors.clear()
注意:对于ForeignKey对象,clear()和remove()方法仅在null=True时存在。

聚合查询和分组

聚合
	aggregate()是QuerySet 的一个终止子句,意思是说,它返回一个包含一些键值对的字典。
	键的名称是聚合值的标识符,值是计算出来的聚合值。键的名称是按照字段和聚合函数的名称自动生成出来的。

	用到的内置函数:
	from django.db.models import Avg, Sum, Max, Min, Count
	models.Book.objects.all().aggregate(Avg("price"))
	如果你想要为聚合值指定一个名称,可以向聚合子句提供它。
	models.Book.objects.all().aggregate(average_price=Avg('price'))
	
分组
	单独表的分组查询
	
	from django.db.models import Avg
	models.Employee.objects.all().values("dept").annotate(avg=Avg("salary")).values("dept","avg")
	
	连表分组的查询
	from django.db.models import Avg
	models.Dept.objects.annotate(avg=Avg("employee__salary")).values("name","avg")

F查询和Q查询

from django.db.models import F
F可以取到字段keep_num的值,和commnet_num比较
models.Book.objects.filter(commnet_num__gt=F('keep_num'))

查询作者名是小仙女或小魔女的
models.Book.objects.filter(Q(authors__name="小仙女")|Q(authors__name="小魔女"))
查询函数可以混合使用Q对象和关键字参数。所有提供给查询函数的参数(关键字参数或Q 对象)都将"AND”在一起。但是,如果出现Q对象,它必须位于所有关键字参数的前面。
models.Book.objects.filter(Q(publish_date__year=2018) | Q(publish_date__year=2017), title__icontains="物语")
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值