mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			220 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			220 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from datetime import datetime
 | |
| 
 | |
| from django.core.exceptions import ValidationError
 | |
| from django.db import models
 | |
| from django.db.models.functions import Lower
 | |
| 
 | |
| 
 | |
| def validate_answer_to_universe(value):
 | |
|     if value != 42:
 | |
|         raise ValidationError(
 | |
|             "This is not the answer to life, universe and everything!", code="not42"
 | |
|         )
 | |
| 
 | |
| 
 | |
| class ModelToValidate(models.Model):
 | |
|     name = models.CharField(max_length=100)
 | |
|     created = models.DateTimeField(default=datetime.now)
 | |
|     number = models.IntegerField(db_column="number_val")
 | |
|     parent = models.ForeignKey(
 | |
|         "self",
 | |
|         models.SET_NULL,
 | |
|         blank=True,
 | |
|         null=True,
 | |
|         limit_choices_to={"number": 10},
 | |
|     )
 | |
|     email = models.EmailField(blank=True)
 | |
|     ufm = models.ForeignKey(
 | |
|         "UniqueFieldsModel",
 | |
|         models.SET_NULL,
 | |
|         to_field="unique_charfield",
 | |
|         blank=True,
 | |
|         null=True,
 | |
|     )
 | |
|     url = models.URLField(blank=True)
 | |
|     f_with_custom_validator = models.IntegerField(
 | |
|         blank=True, null=True, validators=[validate_answer_to_universe]
 | |
|     )
 | |
|     f_with_iterable_of_validators = models.IntegerField(
 | |
|         blank=True, null=True, validators=(validate_answer_to_universe,)
 | |
|     )
 | |
|     slug = models.SlugField(blank=True)
 | |
| 
 | |
|     def clean(self):
 | |
|         super().clean()
 | |
|         if self.number == 11:
 | |
|             raise ValidationError("Invalid number supplied!")
 | |
| 
 | |
| 
 | |
| class UniqueFieldsModel(models.Model):
 | |
|     unique_charfield = models.CharField(max_length=100, unique=True)
 | |
|     unique_integerfield = models.IntegerField(unique=True)
 | |
|     non_unique_field = models.IntegerField()
 | |
| 
 | |
| 
 | |
| class CustomPKModel(models.Model):
 | |
|     my_pk_field = models.CharField(max_length=100, primary_key=True)
 | |
| 
 | |
| 
 | |
| class UniqueTogetherModel(models.Model):
 | |
|     cfield = models.CharField(max_length=100)
 | |
|     ifield = models.IntegerField()
 | |
|     efield = models.EmailField()
 | |
| 
 | |
|     class Meta:
 | |
|         unique_together = (
 | |
|             (
 | |
|                 "ifield",
 | |
|                 "cfield",
 | |
|             ),
 | |
|             ["ifield", "efield"],
 | |
|         )
 | |
| 
 | |
| 
 | |
| class UniqueForDateModel(models.Model):
 | |
|     start_date = models.DateField()
 | |
|     end_date = models.DateTimeField()
 | |
|     count = models.IntegerField(
 | |
|         unique_for_date="start_date", unique_for_year="end_date"
 | |
|     )
 | |
|     order = models.IntegerField(unique_for_month="end_date")
 | |
|     name = models.CharField(max_length=100)
 | |
| 
 | |
| 
 | |
| class CustomMessagesModel(models.Model):
 | |
|     other = models.IntegerField(blank=True, null=True)
 | |
|     number = models.IntegerField(
 | |
|         db_column="number_val",
 | |
|         error_messages={"null": "NULL", "not42": "AAARGH", "not_equal": "%s != me"},
 | |
|         validators=[validate_answer_to_universe],
 | |
|     )
 | |
| 
 | |
| 
 | |
| class AuthorManager(models.Manager):
 | |
|     def get_queryset(self):
 | |
|         qs = super().get_queryset()
 | |
|         return qs.filter(archived=False)
 | |
| 
 | |
| 
 | |
| class Author(models.Model):
 | |
|     name = models.CharField(max_length=100)
 | |
|     archived = models.BooleanField(default=False)
 | |
| 
 | |
|     objects = AuthorManager()
 | |
| 
 | |
| 
 | |
| class Article(models.Model):
 | |
|     title = models.CharField(max_length=100)
 | |
|     author = models.ForeignKey(Author, models.CASCADE)
 | |
|     pub_date = models.DateTimeField(blank=True)
 | |
| 
 | |
|     def clean(self):
 | |
|         if self.pub_date is None:
 | |
|             self.pub_date = datetime.now()
 | |
| 
 | |
| 
 | |
| class Post(models.Model):
 | |
|     title = models.CharField(max_length=50, unique_for_date="posted", blank=True)
 | |
|     slug = models.CharField(max_length=50, unique_for_year="posted", blank=True)
 | |
|     subtitle = models.CharField(max_length=50, unique_for_month="posted", blank=True)
 | |
|     posted = models.DateField()
 | |
| 
 | |
| 
 | |
| class FlexibleDatePost(models.Model):
 | |
|     title = models.CharField(max_length=50, unique_for_date="posted", blank=True)
 | |
|     slug = models.CharField(max_length=50, unique_for_year="posted", blank=True)
 | |
|     subtitle = models.CharField(max_length=50, unique_for_month="posted", blank=True)
 | |
|     posted = models.DateField(blank=True, null=True)
 | |
| 
 | |
| 
 | |
| class UniqueErrorsModel(models.Model):
 | |
|     name = models.CharField(
 | |
|         max_length=100,
 | |
|         unique=True,
 | |
|         error_messages={"unique": "Custom unique name message."},
 | |
|     )
 | |
|     no = models.IntegerField(
 | |
|         unique=True, error_messages={"unique": "Custom unique number message."}
 | |
|     )
 | |
| 
 | |
| 
 | |
| class GenericIPAddressTestModel(models.Model):
 | |
|     generic_ip = models.GenericIPAddressField(blank=True, null=True, unique=True)
 | |
|     v4_ip = models.GenericIPAddressField(blank=True, null=True, protocol="ipv4")
 | |
|     v6_ip = models.GenericIPAddressField(blank=True, null=True, protocol="ipv6")
 | |
|     ip_verbose_name = models.GenericIPAddressField(
 | |
|         "IP Address Verbose", blank=True, null=True
 | |
|     )
 | |
| 
 | |
| 
 | |
| class GenericIPAddrUnpackUniqueTest(models.Model):
 | |
|     generic_v4unpack_ip = models.GenericIPAddressField(
 | |
|         null=True, blank=True, unique=True, unpack_ipv4=True
 | |
|     )
 | |
| 
 | |
| 
 | |
| class UniqueFuncConstraintModel(models.Model):
 | |
|     field = models.CharField(max_length=255)
 | |
| 
 | |
|     class Meta:
 | |
|         required_db_features = {"supports_expression_indexes"}
 | |
|         constraints = [
 | |
|             models.UniqueConstraint(Lower("field"), name="func_lower_field_uq"),
 | |
|         ]
 | |
| 
 | |
| 
 | |
| class Product(models.Model):
 | |
|     price = models.IntegerField(null=True)
 | |
|     discounted_price = models.IntegerField(null=True)
 | |
| 
 | |
|     class Meta:
 | |
|         required_db_features = {
 | |
|             "supports_table_check_constraints",
 | |
|         }
 | |
|         constraints = [
 | |
|             models.CheckConstraint(
 | |
|                 check=models.Q(price__gt=models.F("discounted_price")),
 | |
|                 name="price_gt_discounted_price_validation",
 | |
|             ),
 | |
|         ]
 | |
| 
 | |
| 
 | |
| class ChildProduct(Product):
 | |
|     class Meta:
 | |
|         required_db_features = {
 | |
|             "supports_table_check_constraints",
 | |
|         }
 | |
| 
 | |
| 
 | |
| class UniqueConstraintProduct(models.Model):
 | |
|     name = models.CharField(max_length=255)
 | |
|     color = models.CharField(max_length=32)
 | |
|     rank = models.IntegerField()
 | |
| 
 | |
|     class Meta:
 | |
|         constraints = [
 | |
|             models.UniqueConstraint(
 | |
|                 fields=["name", "color"], name="name_color_uniq_validation"
 | |
|             ),
 | |
|             models.UniqueConstraint(fields=["rank"], name="rank_uniq_validation"),
 | |
|         ]
 | |
| 
 | |
| 
 | |
| class ChildUniqueConstraintProduct(UniqueConstraintProduct):
 | |
|     pass
 | |
| 
 | |
| 
 | |
| class UniqueConstraintConditionProduct(models.Model):
 | |
|     name = models.CharField(max_length=255)
 | |
|     color = models.CharField(max_length=31, null=True, blank=True)
 | |
| 
 | |
|     class Meta:
 | |
|         required_db_features = {"supports_partial_indexes"}
 | |
|         constraints = [
 | |
|             models.UniqueConstraint(
 | |
|                 fields=["name"],
 | |
|                 name="name_without_color_uniq_validation",
 | |
|                 condition=models.Q(color__isnull=True),
 | |
|             ),
 | |
|         ]
 |