mirror of
https://github.com/django/django.git
synced 2024-12-22 17:16:24 +00:00
f387d024fc
Adds support for joint predicates against window annotations through subquery wrapping while maintaining errors for disjointed filter attempts. The "qualify" wording was used to refer to predicates against window annotations as it's the name of a specialized Snowflake extension to SQL that is to window functions what HAVING is to aggregates. While not complete the implementation should cover most of the common use cases for filtering against window functions without requiring the complex subquery pushdown and predicate re-aliasing machinery to deal with disjointed predicates against columns, aggregates, and window functions. A complete disjointed filtering implementation should likely be deferred until proper QUALIFY support lands or the ORM gains a proper subquery pushdown interface.
32 lines
993 B
Python
32 lines
993 B
Python
from django.db import models
|
|
|
|
|
|
class Classification(models.Model):
|
|
code = models.CharField(max_length=10)
|
|
|
|
|
|
class Employee(models.Model):
|
|
name = models.CharField(max_length=40, blank=False, null=False)
|
|
salary = models.PositiveIntegerField()
|
|
department = models.CharField(max_length=40, blank=False, null=False)
|
|
hire_date = models.DateField(blank=False, null=False)
|
|
age = models.IntegerField(blank=False, null=False)
|
|
classification = models.ForeignKey(
|
|
"Classification", on_delete=models.CASCADE, null=True
|
|
)
|
|
bonus = models.DecimalField(decimal_places=2, max_digits=15, null=True)
|
|
|
|
|
|
class PastEmployeeDepartment(models.Model):
|
|
employee = models.ForeignKey(
|
|
Employee, related_name="past_departments", on_delete=models.CASCADE
|
|
)
|
|
department = models.CharField(max_length=40, blank=False, null=False)
|
|
|
|
|
|
class Detail(models.Model):
|
|
value = models.JSONField()
|
|
|
|
class Meta:
|
|
required_db_features = {"supports_json_field"}
|