# 如果获取不到符合条件的数据,会返回空的查询集也叫结果集 <QuerySet []>
# 惰性查询,需要的时候才去查询,如果不需要则不会执行查询,
# 在使用,if,序列化,迭代时,会对查询集合求值
# 查询数据对象的集合,叫做查询集或结果集,如下:
# <QuerySet [<Users: Users object>, <Users: Users object>, <Users: Users object>]>
如果返回使用str魔术方法,那么会返回这样的查询集
def __str__(self):
return self.username
#return '名字:'+self.username+'年龄:'+self.sex
<QuerySet [<Users: 哒哒>, <Users: 嘟嘟>, <Users: 滴滴>]>
#<QuerySet [<Users: 名字:哒哒;年龄:20>, <Users: 嘟嘟;年龄:20>, <Users: 滴滴;年龄:20>]>
# 获取User数据库,所有的数据
# data = Users.objects.all()
# <QuerySet [<Users: Users object>, <Users: Users object>, <Users: Users object>]>
# 尽量不使用此查询方式,上面把值赋给一个变量,可复用,而下面这个,每用一次就要查询一次,徒增开销
for i in User.objects.all()
pass
for i in User.objects.all()
pass
# 条件过滤 filter() 要sex=0的数据
data = Users.objects.filter(sex=0)
data = Users.objects.filter(sex=0,age=22)
data = Users.objects.filter(sex=0).filter(age=26)
# 条件排除 exclude() 就是不要sex=0的数据
data = Users.objects.exclude(sex=0)
# 排序 order_by() 对查询出来的数据以order_by对id进行排序
data = Users.objects.all().order_by('-id')
# values() 一个对象构成一个字典,然后构成一个列表返回,限制返回的字段
data = Users.objects.all().values()
# 这里只返回id,username,age字段
data = Users.objects.all().values('id','username','age')
# get() 获取一个对象
data = Users.objects.get(id=1)
# 返回的是一个对象,不再是一个查询集,
'''
get如果查询不到符合条件的数据 则抛出异常 DoesNotExist at /demo/ Users matching query does not exist.
get如果查询到多条数据,抛出异常 MultipleObjectsReturned at /demo/ get() returned more than one Users -- it returned 2!
'''
# count() 统计并返回查询条件的总条数
# data = Users.objects.all()
# print(data.count())
# first last
# first 返回符合条件的第一个对象
# last 返回符合条件的最后一个对象
# data = Users.objects.filter(sex=0).first()
# exists() 检测查询条件的数据是否存在 返回 True 或 False
# data = Users.objects.filter(sex=2).exists()
# 数据库limit的用法,不支持负数索引 [0] = [0:1],如果查询为空,就会报错
# 使用下标返回一个新的查询集
#从0开始,取5条
data = Users.objects.filter(sex=0)[:5]
# 跳过前五条,去除后面的10条
data = Users.objects.filter(sex=0)[5:10]
# django中where查询 frlter() exclude() get() 加参数进行where 进行查询
# 比较运算符 大于号=gt 小于号=lt
# data = Users.objects.filter(age__gt=20)
# gt,gte,lt,lte : 大于,大于等于,小于,小于等于
#包含查询 like 模糊查询 contains严格区分大小写搜索 icoontainsb不区分大小写搜索
# select * from user where name like '%admin%';
# data = Users.objects.filter(username__contains='a')
# data = Users.objects.filter(username__icontains='a')
# startswith 查询以'a'开头的,大小写敏感
# data = Users.objects.filter(username__startswith='a')
# endwith 查询以'a'开头的,大小写敏感
# data = Users.objects.filter(username__endwith='a')
isnull,isnotnull 判断是否为null
filter(a___isnull=False)
# in
# select * from user where id in 1,23
# 条件id包含1和23的
data = Users.objects.filter(id__in=[1,23])
#year,month,day,hour,minute,second:对日期类型的属性进行运算
filter(times__year=1960)
# or
# select * from users where username like '%ab%' or age like '%ab%' or email like '%ab%';
filter(Q(条件)|Q(条件))
# from django.db.models import Q
# data = Users.objects.filter(Q(username__contains='ab')|Q(age__contains='ab')|Q(email__contains='ab'))
# print(data)
docsdjangoproject.com/een/1.1
django内置数据库常用查询
猜你喜欢
转载自blog.csdn.net/Doraemon_meow_meow/article/details/90055500
今日推荐
周排行