pl:python:metawmodelach
Różnice
Różnice między wybraną wersją a wersją aktualną.
| Poprzednia rewizja po obu stronachPoprzednia wersjaNowa wersja | Poprzednia wersja | ||
| pl:python:metawmodelach [2023/12/01 12:07] – [default_related_name] sindap | pl:python:metawmodelach [2023/12/08 09:06] (aktualna) – [abstract] sindap | ||
|---|---|---|---|
| Linia 2: | Linia 2: | ||
| ===== abstract ===== | ===== abstract ===== | ||
| + | |||
| + | Opcja '' | ||
| + | |||
| + | Przykład użycia '' | ||
| + | |||
| + | <code python> | ||
| + | from django.db import models | ||
| + | |||
| + | class AbstractModel(models.Model): | ||
| + | common_field = models.CharField(max_length=100) | ||
| + | |||
| + | class Meta: | ||
| + | abstract = True | ||
| + | |||
| + | class ConcreteModel(AbstractModel): | ||
| + | specific_field = models.IntegerField() | ||
| + | </ | ||
| + | |||
| + | W tym przykładzie, | ||
| + | |||
| + | Główne zastosowania '' | ||
| + | |||
| + | 1. **Współdzielenie kodu:** Modele abstrakcyjne pozwalają na zdefiniowanie wspólnej funkcjonalności i pól, które można użyć w wielu modelach. Dzięki temu można unikać powtarzania kodu. | ||
| + | |||
| + | 2. **Strukturyzacja kodu:** Działa jako narzędzie do organizacji kodu, gdy pewne właściwości lub metody są wspólne dla wielu modeli. | ||
| + | |||
| + | Pamiętaj, że modele abstrakcyjne same w sobie nie tworzą tabel w bazie danych, więc nie są bezpośrednio używane do przechowywania danych. Są jedynie punktem wyjścia do dziedziczenia dla innych modeli, które mają związaną tabelę w bazie danych. | ||
| + | |||
| + | Statystycznie najczęściej w takich modelach umieszczane są pola związane z zarządzaniem czasem, takie jak pola '' | ||
| + | |||
| + | Przykłady pól, które mogą być umieszczane w modelu abstrakcyjnym: | ||
| + | |||
| + | 1. **created_at: | ||
| + | 2. **modified_at: | ||
| + | 3. **created_by, | ||
| + | 4. **is_active: | ||
| + | 5. **description: | ||
| + | 6. **slug:** Unikalny identyfikator tekstowy, często używany w adresach URL.\\ | ||
| + | |||
| + | Poniżej przykład takiego wpisu: | ||
| + | |||
| + | <code python> | ||
| + | from django.db import models | ||
| + | from django.utils import timezone | ||
| + | |||
| + | class BaseModel(models.Model): | ||
| + | created_at = models.DateTimeField(auto_now_add=True, | ||
| + | modified_at = models.DateTimeField(auto_now=True, | ||
| + | |||
| + | class Meta: | ||
| + | abstract = True | ||
| + | |||
| + | class YourModel1(BaseModel): | ||
| + | # Twoje pola dla modelu 1 | ||
| + | |||
| + | class YourModel2(BaseModel): | ||
| + | # Twoje pola dla modelu 2 | ||
| + | </ | ||
| + | |||
| + | Ostateczny wybór pól zależy od konkretnego przypadku użycia i wymagań biznesowych. Modele abstrakcyjne są używane w celu uniknięcia powtarzalności kodu i ułatwienia zarządzania wspólnymi właściwościami między wieloma modelami. | ||
| ===== app_label ===== | ===== app_label ===== | ||
| + | |||
| + | Opcja '' | ||
| + | |||
| + | Przykład użycia '' | ||
| + | |||
| + | <code python> | ||
| + | from django.db import models | ||
| + | |||
| + | class MyModel(models.Model): | ||
| + | name = models.CharField(max_length=100) | ||
| + | |||
| + | class Meta: | ||
| + | app_label = ' | ||
| + | </ | ||
| + | |||
| + | W powyższym przykładzie, | ||
| + | |||
| + | Główne zastosowania '' | ||
| + | |||
| + | 1. **Rozstrzyganie konfliktów nazw:** | ||
| + | * Jeśli w różnych aplikacjach masz modele o tej samej nazwie, możesz użyć '' | ||
| + | 2. **Wielokrotne zastosowanie tego samego modelu:** | ||
| + | * W przypadku, gdy ten sam model jest używany w ramach wielu aplikacji, '' | ||
| + | |||
| + | W większości przypadków, | ||
| ===== base_manager_name ===== | ===== base_manager_name ===== | ||
| Linia 169: | Linia 254: | ||
| 1. **base_manager_name: | 1. **base_manager_name: | ||
| - | Przykład użycia base_manager_name`: | + | Przykład użycia |
| - | ```python | + | < |
| - | from django.db import models | + | from django.db import models |
| - | | + | class MyModel(models.Model): |
| - | name = models.CharField(max_length=100) | + | name = models.CharField(max_length=100) |
| - | | + | |
| - | base_manager_name = ' | + | base_manager_name = ' |
| - | ``` | + | </ |
| - | | + | W tym przypadku, |
| - | 2. **`default_manager_name`:** Określa nazwę domyślnego menedżera dla modelu. Domyślny menedżer jest używany do operacji na obiektach modelu, gdy menedżer nie jest specjalnie określony w zapytaniu. To wpływa na menedżera, który jest używany, gdy używamy modelu bezpośrednio, | + | 2. **default_manager_name: |
| - | | + | Przykład użycia |
| - | ```python | + | < |
| - | from django.db import models | + | from django.db import models |
| - | | + | class MyModel(models.Model): |
| - | name = models.CharField(max_length=100) | + | name = models.CharField(max_length=100) |
| - | | + | |
| - | default_manager_name = ' | + | default_manager_name = ' |
| - | ``` | + | </ |
| - | | + | W tym przypadku, |
| - | Podsumowując, | + | Podsumowując, |
| ===== get_latest_by ===== | ===== get_latest_by ===== | ||
pl/python/metawmodelach.1701428828.txt.gz · ostatnio zmienione: przez sindap
