对象的方法
<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="物语")