时间:2021-05-22
F()函数
F()函数的导入
from django.db.models import F
为什么要使用F()函数?
一个 F()对象代表了一个model的字段值或注释列。使用它就可以直接参考model的field和执行数据库操作而不用再把它们(model field)查询出来放到python内存中。
开发个人博客时,统计每篇文章浏览量的逻辑通常是这样写的:
post = Post.objects.get(...)post.views += 1post.save()上面的语句已经相当简短了,但实际上还有更好的办法,就是运用F函数:
from django.db.models import Fpost = Post.objects.get(...)post.views = F('views') + 1post.save()看起来似乎都差不多,但是用F函数有几个显著的好处:
注意,正因为F函数没有在内存中操作,因此更新完数据后需要重新刷新内存中的模型对象:
...post.save()# 重新取值post = Post.objects.get(...)或者这样:
...post.save()# 重新取值post.refresh_from_db()Done!
除此之外,F函数还支持跨字段的查找:
# models.pyclass Age(models.Model): year = models.IntegerField(default=6) month = models.IntegerField(default=10)# --------------# 获取所有 year > month 的数据res = Age.objects.filter(year__gt=F('month'))F函数支持加,减,乘,除,取模和幂运算:
Age.objects.filter(year__gt=F('month') * 2)Age.objects.filter(year__gt=F('month') + F('year'))对于日期字段,也可以轻松处理:
>>> from datetime import timedelta>>> Entry.objects.filter(date__gt=F('pub_date') + timedelta(days=3))跨关系的查找也是可以的:
# models.pyclass Person(...): name = ...class People(...): name = ...class Age(...): ... person = models.OneToOneField(Person, ...) people = models.OneToOneField(People, ...)# --------------# 获取所有 person.name == user.name 的数据res = Age.objects.filter(person__name=F('people__name'))F函数还有一些更高级的用法,如与聚合的配合,这里就不列举了,有兴趣的可以前往文档观摩。
到此这篇关于Django中F函数的使用的文章就介绍到这了,更多相关Django中F函数内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Django框架models使用groupby详解:首先,看下列代码:UserData.objects.filter(hubid=sensorid,time__
pyecharts是一个封装百度开源图表库echarts的包,使用pyecharts可以生成独立的网页,也可以在flask、django中集成使用。示例如下:f
一、go代码中使用C代码go代码中使用C代码,在go语言的函数块中,以注释的方式写入C代码,然后紧跟import“C”即可在go代码中使用C函数代码示例:go代
支持聚合函数的方法:提到聚合函数,首先我们要知道的就是这些聚合函数是不能在django中单独使用的,要想在django中使用这些聚合函数,就必须把这些聚合函数放
这篇文章主要介绍了简单了解python中的f.b.u.r函数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下f