mirror of
https://github.com/django/django.git
synced 2025-10-23 21:59:11 +00:00
[5.0.x] Refs #34964 -- Doc'd that Q expression order is preserved.
Backport of 7714ccfeae
from main
This commit is contained in:
committed by
Mariusz Felisiak
parent
b1f2833bc4
commit
a8de04f8db
@@ -119,6 +119,18 @@ specifies the check you want the constraint to enforce.
|
||||
For example, ``CheckConstraint(check=Q(age__gte=18), name='age_gte_18')``
|
||||
ensures the age field is never less than 18.
|
||||
|
||||
.. admonition:: Expression order
|
||||
|
||||
``Q`` argument order is not necessarily preserved, however the order of
|
||||
``Q`` expressions themselves are preserved. This may be important for
|
||||
databases that preserve check constraint expression order for performance
|
||||
reasons. For example, use the following format if order matters::
|
||||
|
||||
CheckConstraint(
|
||||
check=Q(age__gte=18) & Q(expensive_check=condition),
|
||||
name="age_gte_18_and_others",
|
||||
)
|
||||
|
||||
.. admonition:: Oracle
|
||||
|
||||
Checks with nullable fields on Oracle must include a condition allowing for
|
||||
|
Reference in New Issue
Block a user