DAY78-Django框架
Posted xvchengqi
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DAY78-Django框架相关的知识,希望对你有一定的参考价值。
一、基于双下划线的查询
一对多
# 查询出版社为北京出版社出版的所有图书的名字,价格
book = models.Book.objects.filter(publish__name=‘北京出版社‘).values(‘name‘,‘price‘)
print(book)
book = models.Publish.objects.filter(name=‘北京出版社‘).values(‘book__name‘,‘book__price‘)
print(book)
# 查询北京出版社出版的价格大于19的书
book=models.Publish.objects.filter(name=‘北京出版社‘,book__price__gt=19).values(‘book__name‘,‘book__price‘)
print(book)
多对多
# 查询红楼梦的所有作者名字
author = models.Book.objects.filter(name=‘红楼梦‘).values(‘authors__name‘)
print(author)
authot = models.Author.objects.filter(book__name=‘红楼梦‘).values(‘name‘)
print(author)
连续跨表
# 查询北京出版社出版过的所有书籍的名字以及作者的姓名
res = models.Publish.objects.filter(name=‘北京出版社‘).values(‘book__name‘,‘book__authors__name‘)
print(res)
# 手机号以13开头的作者出版过的所有书籍名称以及出版社名称
res = models.AuthorDetail.objects.filter(phone__startswith=13).values(‘author__book__name‘,‘author__book__publish__name‘)
print(res)
二、聚合查询
? aggregate()是QuerySet的一个终止子句,意思是说,它返回一个包含一些键值对的字典。键的名称是聚合值的标识符,值是计算出来的聚合值。键的名称是按照字段和聚合函数的名称自动生成出来的。如果你想要为聚合值指定一个名称,可以向聚合子句提供它。
语法
from django.db.models import Avg,Max,Min,Sum,Count
aggregate(*args, **kwargs)
实例
from django.db.models import Avg, Count, Max, Min, Sum
# 计算所有图书的平均价格
res = models.Book.objects.all().aggregate(Avg(‘price‘))
print(res)
# 计算图书的最高价格
res = models.Book.objects.all().aggregate(Max(‘price‘))
print(res)
# 计算图书的最高价格,最低价格,平均价格,总价
res = models.Book.objects.all().aggregate(Max(‘price‘),Min(‘price‘),Avg(‘price‘),Sum(‘price‘))
print(res)
三、分组查询
? annotate()为调用的QuerySet中每一个对象都生成一个独立的统计值(统计方法用聚合函数)。
语法
from django.db.models import Avg,Max,Min,Sum,Count
annotate(*args, **kwargs)
实例
# 前提
# 1.group by 谁,就以谁做基表,filter过滤,annotate取分组,values取值
# 2.values在annotate前,表示group by,写任意基表的字段即可,values也可以省略不写,默认是id;在annotate后,表示取值
# 3.filter在annotate前,表示where条件,在annotate后,表示having
# 统计每一本书作者个数
res = models.Book.objects.all().annotate(c=Count(‘authors‘)).values(‘name‘,‘c‘)
print(res)
# 统计每一个出版社的最便宜的书
res = models.Publish.objects.all().annotate(m=Min(‘book__price‘)).values(‘name‘,‘m‘)
print(res)
# 查询各个作者出的书的总价格
#values在前可以忽略
res = models.Author.objects.all().values(‘name‘).annotate(s=Sum(‘book__price‘)).values(‘name‘,‘s‘)
print(res)
res = models.Author.objects.all().annotate(s=Sum(‘book__price‘)).values(‘name‘,‘s‘)
print(res)
# 查询所有在北京的作者写的书的总价格大于30
res = models.Author.objects.filter(authordetail__addr=‘北京‘).annotate(s=Sum(‘book__price‘)).filter(s__gt=30).values(‘name‘,‘s‘)
print(res)
四、F查询
在上面所有的例子中,我们构造的过滤器都只是将字段值与某个常量做比较。如果我们要对两个字段的值做比较,那该怎么做呢?
Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。
语法
from django.db.models import F
F(字段名)
实例
from django.db.models import F
# 查询评论数大于收藏数的书籍
models.Book.objects.filter(commnetNum__lt=F(‘keepNum‘))
# 所有的书价格+1
models.Book.objects.all().update(price = F(‘price‘)+1)
五、Q查询
? filter()等方法中的关键字参数查询都是一起进行“AND” 的。 如果你需要执行更复杂的查询(例OR 语句),你可以使用Q对象。
? Q对象可以使用& 和| 操作符组合起来。当一个操作符在两个Q对象上使用时,它产生一个新的Q 对象。
语法
#与& 或| 非~
Q()
实例
from django.db.models import Q
# 查询名字叫红楼梦或者价格大于100的书
res = models.Book.objects.filter(Q(name=‘红楼梦‘)|Q(price__gt=100)).values(‘name‘,‘price‘)
print(res)
# 查询名字叫红楼梦和价格大于100的书
res = models.Book.objects.filter(Q(name=‘红楼梦‘)&Q(price__gt=100)).values(‘name‘,‘price‘)
print(res)
#查询不是名字红楼梦的书
res = models.Book.objects.filter(~Q(name=‘红楼梦‘))
print(res)
六、ORM字段
常用
#AutoField
int自增列,必须填入参数 primary_key=True。当model中如果没有自增列,则自动会创建一个列名为id的列。
#IntegerField
一个整数类型,范围在 -2147483648 to 2147483647。
#CharField
字符类型,必须提供max_length参数, max_length表示字符长度。
#DateField
日期字段,日期格式 YYYY-MM-DD,相当于Python中的datetime.date()实例。
#DateTimeField
日期时间字段,格式 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ],相当于Python中的datetime.datetime()实例
非常用
#AutoField(Field)
- int自增列,必须填入参数 primary_key=True
#BigAutoField(AutoField)
- bigint自增列,必须填入参数 primary_key=True
注:当model中如果没有自增列,则自动会创建一个列名为id的列
#SmallIntegerField(IntegerField):
- 小整数 -32768 ~ 32767
#PositiveSmallIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField)
- 正小整数 0 ~ 32767
#IntegerField(Field)
- 整数列(有符号的) -2147483648 ~ 2147483647
#PositiveIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField)
- 正整数 0 ~ 2147483647
#BigIntegerField(IntegerField):
- 长整型(有符号的) -9223372036854775808 ~ 9223372036854775807
#BooleanField(Field)
- 布尔值类型
#NullBooleanField(Field):
- 可以为空的布尔值
#CharField(Field)
- 字符类型
- 必须提供max_length参数, max_length表示字符长度
#TextField(Field)
- 文本类型
#EmailField(CharField):
- 字符串类型,Django Admin以及ModelForm中提供验证机制
#IPAddressField(Field)
- 字符串类型,Django Admin以及ModelForm中提供验证 IPV4 机制
#GenericIPAddressField(Field)
- 字符串类型,Django Admin以及ModelForm中提供验证 Ipv4和Ipv6
- 参数:
protocol,用于指定Ipv4或Ipv6, ‘both‘,"ipv4","ipv6"
unpack_ipv4, 如果指定为True,则输入::ffff:192.0.2.1时候,可解析为192.0.2.1,开启此功能,需要protocol="both"
#URLField(CharField)
- 字符串类型,Django Admin以及ModelForm中提供验证 URL
#SlugField(CharField)
- 字符串类型,Django Admin以及ModelForm中提供验证支持 字母、数字、下划线、连接符(减号)
#CommaSeparatedIntegerField(CharField)
- 字符串类型,格式必须为逗号分割的数字
#UUIDField(Field)
- 字符串类型,Django Admin以及ModelForm中提供对UUID格式的验证
#FilePathField(Field)
- 字符串,Django Admin以及ModelForm中提供读取文件夹下文件的功能
- 参数:
path, 文件夹路径
match=None, 正则匹配
recursive=False, 递归下面的文件夹
allow_files=True, 允许文件
allow_folders=False, 允许文件夹
#FileField(Field)
- 字符串,路径保存在数据库,文件上传到指定目录
- 参数:
upload_to = "" 上传文件的保存路径
storage = None 存储组件,默认django.core.files.storage.FileSystemStorage
#ImageField(FileField)
- 字符串,路径保存在数据库,文件上传到指定目录
- 参数:
upload_to = "" 上传文件的保存路径
storage = None 存储组件,默认django.core.files.storage.FileSystemStorage
width_field=None, 上传图片的高度保存的数据库字段名(字符串)
height_field=None 上传图片的宽度保存的数据库字段名(字符串)
#DateTimeField(DateField)
- 日期+时间格式 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ]
#DateField(DateTimeCheckMixin, Field)
- 日期格式 YYYY-MM-DD
#TimeField(DateTimeCheckMixin, Field)
- 时间格式 HH:MM[:ss[.uuuuuu]]
#DurationField(Field)
- 长整数,时间间隔,数据库中按照bigint存储,ORM中获取的值为datetime.timedelta类型
#FloatField(Field)
- 浮点型
#DecimalField(Field)
- 10进制小数
- 参数:
max_digits,小数总长度
decimal_places,小数位长度
#BinaryField(Field)
- 二进制类型
七、字段参数
#null
用于表示某个字段可以为空
#unique
唯一性约束,如果设置为unique=True 则该字段在此表中必须是唯一的 。
#default
为该字段设置默认值
#db_index
为该字段建索引
只给日期类型和时间类型用
#auto_now_add
新增数据时,默认把当前时间存入
#auto_now
修改的时候,默认把当前时间存入
八、关系字段
ForeignKey
#to
关联哪个表
#to_field
关联的字段
#related_name
反向操作时,使用的字段名,用于代替原反向查询时的‘表名_set‘。(一般不要用)
#related_query_name
基于双下划线的反向查询之前按表名小写(一般不要用)
#on_delete
当删除关联表中的数据时,当前表与其关联的行的行为。
#models.CASCADE
删除关联数据,与之关联也删除
#models.DO_NOTHING
删除关联数据,引发错误IntegrityError
#models.PROTECT
删除关联数据,引发错误ProtectedError
#models.SET_NULL
删除关联数据,与之关联的值设置为null(前提FK字段需要设置为可空)
#models.SET_DEFAULT
删除关联数据,与之关联的值设置为默认值(前提FK字段需要设置默认值)
#models.SET
删除关联数据,
a. 与之关联的值设置为指定值,设置:models.SET(值)
b. 与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象)
#db_constraint
db_constraint=False代表,不做外键关联
以上是关于DAY78-Django框架的主要内容,如果未能解决你的问题,请参考以下文章
text 来自Codyhouse框架的Browserlist片段源代码