Django ORM 操作 必知必会13条 单表查询

ORM 操作 必知必会13条

import os
# if __name__ == '__main__':  # 当前文件下执行
os.environ.setdefault('DJANGO_SETTINGS_MODULE','orm_p.settings')
import django
django.setup()  # 初始设置  脚本 加载了Django环境

from app01 import models
ret = models.Person.objects.all()        # QuerySet   all 所有
ret = models.Person.objects.get(pk=101)  # 获取不到或者多个就报错   获取某一条数据  对象
ret = models.Person.objects.filter(name = 'alex') # QuerySet  对象列表 满足条件
ret = models.Person.objects.exclude(name = 'alex')# 满足条件后取反--反选 对象列表
ret = models.Person.objects.values() # QuerySet  获取数据所有字段的值 不再是对象,变成字典
ret = models.Person.objects.filter(name = 'alex').values() # QuerySet  获取条件数据所有字段的值 不再是对象,变成字典
ret = models.Person.objects.filter(name = 'alex').values('pid','name') # QuerySet  获取条件数据所有字段的值 不再是对象,变成字典
        # 不指定字段显示所有,指定字段显示选择内容  { 值 值}
ret = models.Person.objects.filter(name = 'alex').values_list() # QuerySet  获取条件数据所有字段的值 不再是对象,变成字典
        # 获取字段的值 元组 ( 值 值 )        --> 传字段

ret = models.Person.objects.all().order_by('-pid','age')  # 升序   -pid 降序  左优先  多个字段排序

ret =ret.reverse()  # 排好序的 后面反转的

ret = models.Person.objects.all()  # 这个用reverse 没效果     models.py 中  class Meta: ordering = ('pid')

ret = models.Person.objects.all().distinct()    # distinct() 去重   mysql不支持按字段去重
ret = models.Person.objects.values('name').distinct()    # distinct() 去重

ret = models.Person.objects.count()  # 计数
ret = models.Person.objects.filter(pid=122).first() # 第一个   查不到/不报错/返回None
ret = models.Person.objects.all().last()  # 取最后一个
ret = models.Person.objects.filter(pid=100).exists()  # 查存在不  返回True/Flase


总结:
返回queryset的有 
all() , filter() , exclude() , order_by() , reverse() , distinct()

特殊的queryset的有 
values()  values_list()

返回数字的:
count()

返回具体对象的
get()  first()  last()

返回布尔值的
exists()

  单表的双下划线方法

import os

os.environ.setdefault('DJANGO_SETTINGS_MODULE','orm_p.settings')
import django
django.setup()   # 初始化

# 单表查询
from app01 import models

ret = models.Person.objects.filter(pk__gt=100) # greater than 大于
ret = models.Person.objects.filter(pk__lt=100) # less than 小于
ret = models.Person.objects.filter(pk__gte=100) # greater than equal 大于等于
ret = models.Person.objects.filter(pk__lte=100) #小于等于
ret = models.Person.objects.filter(pk__in=[100,103]) #查几个

ret = models.Person.objects.exclude(pk__in=[100,103]) #原生sql 中的 not in

ret = models.Person.objects.filter(pk__lte=103,pk__gte=100) # 大于等于 -- 小于等于
ret = models.Person.objects.filter(pk__range=[100,103])     # 什么范围
ret = models.Person.objects.filter(name__contains = 'l') # 原生sql中的 like 包含 
ret = models.Person.objects.filter(name__icontains = 'L') # 大小写  不敏感
ret = models.Person.objects.filter(name__startswith = 'x') # 开头 
ret = models.Person.objects.filter(name__istartswith = 'X') # 不敏感处理 
ret = models.Person.objects.filter(name__endswith = 'X') # 以什么结束

ret = models.Person.objects.filter(name__iendswith = 'X') #  不敏感处理
ret = models.Person.objects.filter(birth__year='2019') #条件查询
ret = models.Person.objects.filter(birth__month='01') # 查不到 
ret = models.Person.objects.filter(birth__contains='2019-01-24') # 能查了 
ret = models.Person.objects.filter(age__isnull=True) # 是否为空

外键查询

正向查找

对象查找(跨表)
语法:对象.关联字段.字段
book_obj = models.Book.objects.first()  # 第一本书对象
print(book_obj.publisher)  # 得到这本书关联的出版社对象
print(book_obj.publisher.name)  # 得到出版社对象的名称

字段查找(跨表)
语法: 关联字段__字段
print(models.Book.objects.values_list("publisher__name"))
------------------------------------------------------------------
反向查找

对象查找
语法:obj.表名_set
publisher_obj = models.Publisher.objects.first()  # 找到第一个出版社对象
books = publisher_obj.book_set.all()  # 找到第一个出版社出版的所有书
titles = books.values_list("title")  # 找到第一个出版社出版的所有书的书名

字段查找
语法:表名__字段
titles = models.Publisher.objects.values_list("book__title")
原文地址:https://www.cnblogs.com/wangyuqi6688/p/11023930.html