mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Document db_default behavior in BooleanField
This commit is contained in:
@@ -690,15 +690,38 @@ case it can't be included in a :class:`~django.forms.ModelForm`.
|
||||
``BooleanField``
|
||||
----------------
|
||||
|
||||
.. class:: BooleanField(**options)
|
||||
|
||||
class BooleanField(**options)
|
||||
A true/false field.
|
||||
|
||||
The default form widget for this field is :class:`~django.forms.CheckboxInput`,
|
||||
or :class:`~django.forms.NullBooleanSelect` if :attr:`null=True <Field.null>`.
|
||||
The default form widget for this field is CheckboxInput, or NullBooleanSelect if null=True.
|
||||
|
||||
The default value of ``BooleanField`` is ``None`` when :attr:`Field.default`
|
||||
isn't defined.
|
||||
The default value of BooleanField is None when Field.default isn’t defined.
|
||||
|
||||
.. note::
|
||||
|
||||
When using the `db_default` attribute, the field value will be an instance of `DatabaseDefault` before the instance is saved to the database. This means that a `bool()` evaluation of the field will not reflect the specified `db_default` value until the instance is saved.
|
||||
|
||||
For example:
|
||||
|
||||
.. code-block:: python
|
||||
|
||||
from django.db import models
|
||||
|
||||
class MyModel(models.Model):
|
||||
my_field = models.BooleanField(db_default=False)
|
||||
|
||||
my_obj = MyModel()
|
||||
print(bool(my_obj.my_field)) # True, which is unexpected.
|
||||
|
||||
my_obj.save()
|
||||
print(bool(my_obj.my_field)) # False, as expected.
|
||||
|
||||
To ensure the field value reflects the desired default before saving, also set the `default` attribute:
|
||||
|
||||
.. code-block:: python
|
||||
|
||||
class MyModel(models.Model):
|
||||
my_field = models.BooleanField(default=False, db_default=False)
|
||||
|
||||
``CharField``
|
||||
-------------
|
||||
|
Reference in New Issue
Block a user