Django ORM映射与模糊查询
ORM是什么?
在django中,根据代码中的类自动生成数据库的表也叫–code first, ORM:Object Relational Mapping(关系对象映射)
orm使用方式:
orm操作可以使用类实例化,obj.save的方式,也可以使用create()的形式
QuerySet数据类型介绍
QuerySet与惰性机制
所谓惰性机制:Publisher.objects.all()或者.filter()等都只是返回了一个QuerySet(查询结果集对象),它并不会马上执行sql,而是当调用QuerySet的时候才执行。
QuerySet特点:
<1> 可迭代的
<2> 可切片
<3>惰性计算和缓存机制
UserInfo.objects.get(id=2) 等于 select * from user_userinfo where id=2 修改管理器(models.py) 导入新的包:from django.db import models 进行模糊查询 开始进行查找前我们先来认识filter()方法。 这是一个过滤器方法用于过滤掉不符合条件的元素。 值得一提的是其内自带方法函数的引用方式为‘__方法名称’。 __exact 精确等于 like ‘aaa’ __iexact 精确等于 忽略大小写 ilike ‘aaa’ __contains 包含 like ‘%aaa%’ __icontains 包含 忽略大小写 ilike ‘%aaa%’,但是对于sqlite来说,contains的作用效果等同于icontains。 __gt 大于 __gte 大于等于 __lt 小于 __lte 小于等于 __in 存在于一个list范围内 __startswith 以…开头 __istartswith 以…开头 忽略大小写 __endswith 以…结尾 __iendswith 以…结尾,忽略大小写 __range 在…范围内 __year 日期字段的年份 __month 日期字段的月份 __day 日期字段的日 __isnull=True/False __regex=r'^(An?|The) +' 正则匹配 __iregex=r'^(an?|the) +' 正则不区分大小写 __week_day__gte 按星期大于等于查询
例子:
obj1 = UserInfo.objects.filter(user_name__contains='王')#以‘王’开头的user__name obj2 = UserInfo.objects.filter(user_name__endswith='王')#以‘王’结尾的user__name obj3 = UserInfo.objects.filter(id__gte=5)#ID大于等于5的 obj5 = UserInfo.objects.filter(id__exact=5)#id等于5的 obj6 = UserInfo.objects.filter(id__in=[1,3,5])#id等于1,3,5,的
exclude方法,排除选项。
obj8 = UserInfo.objects.filter(password='123456',id__gt=2).exclude(phone=188)
#找到符合filter的内容后排除phone等于188的,它的另一种写法为 from django.db.models import Q obj = UserInfo.objects.filter(Q(password='123456') & Q(id__gt=2) & ~Q(phone=188))
计算和和最大值:
from django.db.models import Sum,Max,Min obj = UserInfo.objects.aggregate(Sum('id')) obj = UserInfo.objects.aggregate(Max('id')) obj = UserInfo.objects.aggregate(Min('id'))
统计个数
print(UserInfo.objects.count()) #注:print只可于终端查看
范围查找
obj = UserInfo.objects.all()[1:3] #左闭右开,只查找了1和2
去重复
obj = person.useraddress_set.all()
而get方法与filter的最大区别为,get只能返回一个数据,filter可以返回多个,在get查找到两个以上数据时就会报错。
obj4 = UserInfo.objects.get(id=5)
city = UserAddress.objects.get(detail=’北京望京’)
Q多条件组合查询
Q()可以使orm的fifter()方法支持, 多个查询条件,使用逻辑关系(&、|、~)包含、组合到一起进行多条件查询;
语法:
fifter(Q(查询条件1)| Q(查询条件2)) fifter(Q(查询条件2)& Q(查询条件3) fifter(Q(查询条件4)& ~Q(查询条件5)) fifter(Q(查询条件6)| Q(Q(查询条件4)& ~ Q(Q(查询条件5)& Q(查询条件3)))包含