Technologieaustausch

F-Objekt in Django ORM

2024-07-12

한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina

F Objekte sind sehr leistungsfähig und können komplexe Aufgaben bei Abfrage- und Aktualisierungsvorgängen ausführen.zwischen FeldernBetrieb.

Angenommen, wir haben ein Modell, das Produktinformationen enthält Product

from django.db import models

class Product(models.Model):
    name = models.CharField(max_length=100)
    price = models.DecimalField(max_digits=10, decimal_places=2)
    discount_price = models.DecimalField(max_digits=10, decimal_places=2)
    stock = models.IntegerField()

    def __str__(self):
        return self.name
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

1. Vergleichen Sie die Werte zweier Felder

Erhalten Sie alle Artikel zu einem reduzierten Preis, der unter dem Originalpreis liegt:

from django.db.models import F

# 获取所有折扣价低于原价的商品
discounted_products = Product.objects.filter(discount_price__lt=F('price'))
for product in discounted_products:
    print(product.name, product.price, product.discount_price)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

2. Arithmetische Operationen zwischen Feldern

Berechnen Sie den Rabattbetrag (Originalpreis minus Rabattpreis) für jeden Artikel und sortieren Sie nach Rabattbetrag:

# 计算每个商品的折扣金额,并按折扣金额排序
products_with_discount = Product.objects.annotate(
    discount_amount=F('price') - F('discount_price')
).order_by('-discount_amount')

for product in products_with_discount:
    print(product.name, product.price, product.discount_price, product.discount_amount)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

3. Verwendung F Objektaktualisierungsvorgang

Erhöhen Sie den Preis aller Artikel, von denen weniger als 10 Stück auf Lager sind, um 10 %:

# 将所有库存少于10的商品的价格提高10%
Product.objects.filter(stock__lt=10).update(price=F('price') * 1.10)
  • 1
  • 2

4. Kombinieren F Objekte und Aggregatfunktionen

Berechnen Sie den durchschnittlichen Rabattbetrag für Artikel mit mehr als 20 Artikeln auf Lager:

from django.db.models import Avg

# 计算库存大于20的商品的平均折扣金额
average_discount = Product.objects.filter(stock__gt=20).annotate(
    discount_amount=F('price') - F('discount_price')
).aggregate(Avg('discount_amount'))

print(average_discount)  # 输出: {'discount_amount__avg': 例如 15.00}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

5. Verwendung F Objekt bedingt aktualisiert

Legen Sie den reduzierten Preis für alle Artikel mit weniger als 10 Artikeln auf Lager auf 90 % des Originalpreises fest:

# 将所有库存少于10的商品的折扣价设置为原价的90%
Product.objects.filter(stock__lt=10).update(discount_price=F('price') * 0.90)
  • 1
  • 2

6. Verwendung F Objekte führen Vergleiche und Filterungen zwischen Feldern durch

Erhalten Sie alle Produkte mit einem Rabatt von mehr als 20:

# 获取所有折扣金额大于20的商品
products_with_large_discount = Product.objects.annotate(
    discount_amount=F('price') - F('discount_price')
).filter(discount_amount__gt=20)

for product in products_with_large_discount:
    print(product.name, product.price, product.discount_price, product.discount_amount)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7