时间:2021-05-22
通常情况下我们在更新数据时需要先从数据库里将原数据取出后放在内存里,然后编辑某些字段或属性,最后提交更新数据库。使用F方法则可以帮助我们避免将所有数据先载入内存,而是直接生成SQL语句更新数据库。
假如我们需要对所有产品的价格涨20%,我们通常做法如下。当产品很少的时候,对网站性能没影响。但如果产品数量非常多,把它们信息全部先载入内存会造成很大性能浪费。
products = Product.objects.all()for product in products: product.price *= 1.2 product.save()使用F方法可以解决上述问题。我们直接可以更新数据库,而不必将所有产品载入内存。
from django.db.models import F
Product.objects.update(price=F('price') * 1.2)
我们也可以使用F方法更新单个对象的字段,如下所示:
product = Product.objects.get(pk=5009)product.price = F('price') * 1.2product.save()但值得注意的是当你使用F方法对某个对象字段进行更新后,需要使用refresh_from_db()方法后才能获取最新的字段信息(非常重要!)。
如下所示:
product.price = F('price') + 1product.save()print(product.price) # <CombinedExpression: F(price) + Value(1)>product.refresh_from_db()print(product.price) # Decimal('13.00')补充知识:Django批量更新多个属性
有时候我们需要同时(一次性)更新某个用户的多条属性。
1. 用户model如下:
class User(models.Model): UID = models.CharField('员工uid', max_length=200,) name = models.CharField('员工名字', max_length=200,) mobile = models.CharField('手机号', max_length=200,) mail = models.EmailField(u'邮箱', max_length=200)2. 用户的数据
user_info = {'UID': 'ADBES682BOEO', 'name': '张三', 'mobile': '12345678911', 'mail': 'test@test.com' }3. 新建用户
User.object.create(UID='ADBES682BOEO',name='张三',mobile='12345678911',mail='test@test.com')
这就会在数据库中新建一个张三的数据。
4. 更新数据
user_info = {'UID': 'ADBES682BOEO', 'name': '张三2', 'mobile': '12345678912', 'mail': 'test2@test.com' }4.1 一般的更新操作
user = User.object.get(UID='ADBES682BOEO')user.name = user_info['name']user.mobile = user_info['mobile']user.mail = user_info['mail']user.save()4.2 批量操作
user = User.object.filter(UID='ADBES682BOEO')user.update(**user_info)以上这篇django使用F方法更新一个对象多个对象字段的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
F()函数F()函数的导入fromdjango.db.modelsimportF为什么要使用F()函数?一个F()对象代表了一个model的字段值或注释
假设一个PS脚本函数需要返回多个值,最好的办法是返回对象并且存储对象独有的属性。这里有一个不错的方法。它能轻松的返回你想要的多个信息,并将结果分配给多个变量:f
使用itertools工具类中的chain方法,可以很方便的将多个iterable对象一起遍历.不过,对于dict类型的iterable对象,只会遍历key.f
Django中Models是什么:通常,一个Model对应一张数据表,Django中Models以类的形式表现,它包含一些基本字段以及数据的一些行为ORM:对象
$.extend方法可以扩展JSON对象,用一个或多个其他对象来扩展一个对象,返回被扩展的对象。例一合并settings和options,修改并返回settin