mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #22809 -- Added model Field API reference.
Thanks to @timgraham for the review.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							b02abd688a
						
					
				
				
					commit
					e1fa7dffdc
				
			| @@ -105,8 +105,6 @@ say, all the *north* cards first, then the *east*, *south* and *west* cards. So | |||||||
| What does a field class do? | What does a field class do? | ||||||
| --------------------------- | --------------------------- | ||||||
|  |  | ||||||
| .. class:: Field |  | ||||||
|  |  | ||||||
| All of Django's fields (and when we say *fields* in this document, we always | All of Django's fields (and when we say *fields* in this document, we always | ||||||
| mean model fields and not :doc:`form fields </ref/forms/fields>`) are subclasses | mean model fields and not :doc:`form fields </ref/forms/fields>`) are subclasses | ||||||
| of :class:`django.db.models.Field`. Most of the information that Django records | of :class:`django.db.models.Field`. Most of the information that Django records | ||||||
| @@ -193,10 +191,7 @@ card values plus their suits; 104 characters in total. | |||||||
|     you want your fields to be more strict about the options they select, or to |     you want your fields to be more strict about the options they select, or to | ||||||
|     use the simpler, more permissive behavior of the current fields. |     use the simpler, more permissive behavior of the current fields. | ||||||
|  |  | ||||||
| .. method:: Field.__init__() | The ``Field.__init__()`` method takes the following parameters: | ||||||
|  |  | ||||||
| The :meth:`~django.db.models.Field.__init__` method takes the following |  | ||||||
| parameters: |  | ||||||
|  |  | ||||||
| * :attr:`~django.db.models.Field.verbose_name` | * :attr:`~django.db.models.Field.verbose_name` | ||||||
| * ``name`` | * ``name`` | ||||||
| @@ -396,15 +391,13 @@ correct datatype. | |||||||
| Documenting your custom field | Documenting your custom field | ||||||
| ----------------------------- | ----------------------------- | ||||||
|  |  | ||||||
| .. attribute:: Field.description |  | ||||||
|  |  | ||||||
| As always, you should document your field type, so users will know what it is. | As always, you should document your field type, so users will know what it is. | ||||||
| In addition to providing a docstring for it, which is useful for developers, | In addition to providing a docstring for it, which is useful for developers, | ||||||
| you can also allow users of the admin app to see a short description of the | you can also allow users of the admin app to see a short description of the | ||||||
| field type via the :doc:`django.contrib.admindocs | field type via the :doc:`django.contrib.admindocs | ||||||
| </ref/contrib/admin/admindocs>` application. To do this simply provide | </ref/contrib/admin/admindocs>` application. To do this simply provide | ||||||
| descriptive text in a ``description`` class attribute of your custom field. In | descriptive text in a :attr:`~Field.description` class attribute of your custom | ||||||
| the above example, the description displayed by the ``admindocs`` | field. In the above example, the description displayed by the ``admindocs`` | ||||||
| application for a ``HandField`` will be 'A hand of cards (bridge style)'. | application for a ``HandField`` will be 'A hand of cards (bridge style)'. | ||||||
|  |  | ||||||
| In the :mod:`django.contrib.admindocs` display, the field description is | In the :mod:`django.contrib.admindocs` display, the field description is | ||||||
| @@ -422,17 +415,13 @@ the ``__metaclass__``, you might consider overriding a few standard methods, | |||||||
| depending on your field's behavior. The list of methods below is in | depending on your field's behavior. The list of methods below is in | ||||||
| approximately decreasing order of importance, so start from the top. | approximately decreasing order of importance, so start from the top. | ||||||
|  |  | ||||||
|  | .. _custom-database-types: | ||||||
|  |  | ||||||
| Custom database types | Custom database types | ||||||
| ~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| .. method:: Field.db_type(connection) | Say you've created a PostgreSQL custom type called ``mytype``. You can | ||||||
|  | subclass ``Field`` and implement the :meth:`~Field.db_type` method, like so:: | ||||||
| Returns the database column data type for the :class:`~django.db.models.Field`, |  | ||||||
| taking into account the connection object, and the settings associated with it. |  | ||||||
|  |  | ||||||
| Say you've created a PostgreSQL custom type called ``mytype``. You can use this |  | ||||||
| field with Django by subclassing ``Field`` and implementing the |  | ||||||
| :meth:`.db_type` method, like so:: |  | ||||||
|  |  | ||||||
|     from django.db import models |     from django.db import models | ||||||
|  |  | ||||||
| @@ -450,7 +439,7 @@ Once you have ``MytypeField``, you can use it in any model, just like any other | |||||||
| If you aim to build a database-agnostic application, you should account for | If you aim to build a database-agnostic application, you should account for | ||||||
| differences in database column types. For example, the date/time column type | differences in database column types. For example, the date/time column type | ||||||
| in PostgreSQL is called ``timestamp``, while the same column in MySQL is called | in PostgreSQL is called ``timestamp``, while the same column in MySQL is called | ||||||
| ``datetime``. The simplest way to handle this in a :meth:`.db_type` | ``datetime``. The simplest way to handle this in a :meth:`~Field.db_type` | ||||||
| method is to check the ``connection.settings_dict['ENGINE']`` attribute. | method is to check the ``connection.settings_dict['ENGINE']`` attribute. | ||||||
|  |  | ||||||
| For example:: | For example:: | ||||||
| @@ -462,7 +451,7 @@ For example:: | |||||||
|             else: |             else: | ||||||
|                 return 'timestamp' |                 return 'timestamp' | ||||||
|  |  | ||||||
| The :meth:`.db_type` method is called by Django when the framework | The :meth:`~Field.db_type` method is called by Django when the framework | ||||||
| constructs the ``CREATE TABLE`` statements for your application -- that is, | constructs the ``CREATE TABLE`` statements for your application -- that is, | ||||||
| when you first create your tables. It is also called when constructing a | when you first create your tables. It is also called when constructing a | ||||||
| ``WHERE`` clause that includes the model field -- that is, when you retrieve data | ``WHERE`` clause that includes the model field -- that is, when you retrieve data | ||||||
| @@ -489,7 +478,7 @@ sense to have a ``CharMaxlength25Field``, shown here:: | |||||||
|  |  | ||||||
| The better way of doing this would be to make the parameter specifiable at run | The better way of doing this would be to make the parameter specifiable at run | ||||||
| time -- i.e., when the class is instantiated. To do that, just implement | time -- i.e., when the class is instantiated. To do that, just implement | ||||||
| :meth:`django.db.models.Field.__init__`, like so:: | ``Field.__init__()``, like so:: | ||||||
|  |  | ||||||
|     # This is a much more flexible example. |     # This is a much more flexible example. | ||||||
|     class BetterCharField(models.Field): |     class BetterCharField(models.Field): | ||||||
| @@ -511,21 +500,14 @@ over this field. You are then responsible for creating the column in the right | |||||||
| table in some other way, of course, but this gives you a way to tell Django to | table in some other way, of course, but this gives you a way to tell Django to | ||||||
| get out of the way. | get out of the way. | ||||||
|  |  | ||||||
|  | .. _converting-database-values-to-python-objects: | ||||||
|  |  | ||||||
| Converting database values to Python objects | Converting database values to Python objects | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| .. method:: Field.to_python(value) | If your custom :class:`~Field` class deals with data structures that are more | ||||||
|  | complex than strings, dates, integers or floats, then you'll need to override | ||||||
| Converts a value as returned by your database (or a serializer) to a Python | :meth:`~Field.to_python`. As a general rule, the method should deal gracefully | ||||||
| object. |  | ||||||
|  |  | ||||||
| The default implementation simply returns ``value``, for the common case in |  | ||||||
| which the database backend already returns data in the correct format (as a |  | ||||||
| Python string, for example). |  | ||||||
|  |  | ||||||
| If your custom :class:`~django.db.models.Field` class deals with data structures |  | ||||||
| that are more complex than strings, dates, integers or floats, then you'll need |  | ||||||
| to override this method. As a general rule, the method should deal gracefully |  | ||||||
| with any of the following arguments: | with any of the following arguments: | ||||||
|  |  | ||||||
| * An instance of the correct type (e.g., ``Hand`` in our ongoing example). | * An instance of the correct type (e.g., ``Hand`` in our ongoing example). | ||||||
| @@ -560,9 +542,9 @@ Python object type we want to store in the model's attribute. If anything is | |||||||
| going wrong during value conversion, you should raise a | going wrong during value conversion, you should raise a | ||||||
| :exc:`~django.core.exceptions.ValidationError` exception. | :exc:`~django.core.exceptions.ValidationError` exception. | ||||||
|  |  | ||||||
| **Remember:** If your custom field needs the :meth:`.to_python` method to be | **Remember:** If your custom field needs the :meth:`~Field.to_python` method to be | ||||||
| called when it is created, you should be using `The SubfieldBase metaclass`_ | called when it is created, you should be using `The SubfieldBase metaclass`_ | ||||||
| mentioned earlier. Otherwise :meth:`.to_python` won't be called | mentioned earlier. Otherwise :meth:`~Field.to_python` won't be called | ||||||
| automatically. | automatically. | ||||||
|  |  | ||||||
| .. warning:: | .. warning:: | ||||||
| @@ -572,21 +554,14 @@ automatically. | |||||||
|     :meth:`~Field.get_prep_value`, should handle the case when ``value`` is |     :meth:`~Field.get_prep_value`, should handle the case when ``value`` is | ||||||
|     ``None``. |     ``None``. | ||||||
|  |  | ||||||
|  | .. _converting-python-objects-to-query-values: | ||||||
|  |  | ||||||
| Converting Python objects to query values | Converting Python objects to query values | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| .. method:: Field.get_prep_value(value) | Since using a database requires conversion in both ways, if you override | ||||||
|  | :meth:`~Field.to_python` you also have to override :meth:`~Field.get_prep_value` | ||||||
| This is the reverse of :meth:`.to_python` when working with the | to convert Python objects back to query values. | ||||||
| database backends (as opposed to serialization). The ``value`` |  | ||||||
| parameter is the current value of the model's attribute (a field has |  | ||||||
| no reference to its containing model, so it cannot retrieve the value |  | ||||||
| itself), and the method should return data in a format that has been |  | ||||||
| prepared for use as a parameter in a query. |  | ||||||
|  |  | ||||||
| This conversion should *not* include any database-specific |  | ||||||
| conversions. If database-specific conversions are required, they |  | ||||||
| should be made in the call to :meth:`.get_db_prep_value`. |  | ||||||
|  |  | ||||||
| For example:: | For example:: | ||||||
|  |  | ||||||
| @@ -607,49 +582,38 @@ For example:: | |||||||
|     objects in their results. This problem cannot occur if you always |     objects in their results. This problem cannot occur if you always | ||||||
|     return a string type from :meth:`.get_prep_value`. |     return a string type from :meth:`.get_prep_value`. | ||||||
|  |  | ||||||
|  | .. _converting-query-values-to-database-values: | ||||||
|  |  | ||||||
| Converting query values to database values | Converting query values to database values | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| .. method:: Field.get_db_prep_value(value, connection, prepared=False) |  | ||||||
|  |  | ||||||
| Some data types (for example, dates) need to be in a specific format | Some data types (for example, dates) need to be in a specific format | ||||||
| before they can be used by a database backend. | before they can be used by a database backend. | ||||||
| :meth:`.get_db_prep_value` is the method where those conversions should | :meth:`~Field.get_db_prep_value` is the method where those conversions should | ||||||
| be made. The specific connection that will be used for the query is | be made. The specific connection that will be used for the query is | ||||||
| passed as the ``connection`` parameter. This allows you to use | passed as the ``connection`` parameter. This allows you to use | ||||||
| backend-specific conversion logic if it is required. | backend-specific conversion logic if it is required. | ||||||
|  |  | ||||||
| The ``prepared`` argument describes whether or not the value has | For example, Django uses the following method for its | ||||||
| already been passed through :meth:`.get_prep_value` conversions. When | :class:``~models.BinaryField``:: | ||||||
| ``prepared`` is False, the default implementation of |  | ||||||
| :meth:`.get_db_prep_value` will call :meth:`.get_prep_value` to do |  | ||||||
| initial data conversions before performing any database-specific |  | ||||||
| processing. |  | ||||||
|  |  | ||||||
| .. method:: Field.get_db_prep_save(value, connection) |     def get_db_prep_value(self, value, connection, prepared=False): | ||||||
|  |         value = super(BinaryField, self).get_db_prep_value(value, connection, prepared) | ||||||
|  |         if value is not None: | ||||||
|  |             return connection.Database.Binary(value) | ||||||
|  |         return value | ||||||
|  |  | ||||||
| Same as the above, but called when the Field value must be *saved* to | In case your custom field needs a special conversion when being saved that is | ||||||
| the database. As the default implementation just calls | not the same as the conversion used for normal query parameters, you can | ||||||
| :meth:`.get_db_prep_value`, you shouldn't need to implement this method | override :meth:`~Field.get_db_prep_save`. | ||||||
| unless your custom field needs a special conversion when being saved |  | ||||||
| that is not the same as the conversion used for normal query | .. _preprocessing-values-before-saving: | ||||||
| parameters (which is implemented by :meth:`.get_db_prep_value`). |  | ||||||
|  |  | ||||||
| Preprocessing values before saving | Preprocessing values before saving | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| .. method:: Field.pre_save(model_instance, add) | If you want to preprocess the value just before saving, you can use | ||||||
|  | :meth:`~Field.pre_save`. For example, Django's | ||||||
| This method is called just prior to :meth:`.get_db_prep_save` and should return |  | ||||||
| the value of the appropriate attribute from ``model_instance`` for this field. |  | ||||||
| The attribute name is in ``self.attname`` (this is set up by |  | ||||||
| :class:`~django.db.models.Field`). If the model is being saved to the database |  | ||||||
| for the first time, the ``add`` parameter will be ``True``, otherwise it will be |  | ||||||
| ``False``. |  | ||||||
|  |  | ||||||
| You only need to override this method if you want to preprocess the value |  | ||||||
| somehow, just before saving. For example, Django's |  | ||||||
| :class:`~django.db.models.DateTimeField` uses this method to set the attribute | :class:`~django.db.models.DateTimeField` uses this method to set the attribute | ||||||
| correctly in the case of :attr:`~django.db.models.DateField.auto_now` or | correctly in the case of :attr:`~django.db.models.DateField.auto_now` or | ||||||
| :attr:`~django.db.models.DateField.auto_now_add`. | :attr:`~django.db.models.DateField.auto_now_add`. | ||||||
| @@ -659,20 +623,20 @@ the end. You should also update the model's attribute if you make any changes | |||||||
| to the value so that code holding references to the model will always see the | to the value so that code holding references to the model will always see the | ||||||
| correct value. | correct value. | ||||||
|  |  | ||||||
|  | .. _preparing-values-for-use-in-database-lookups: | ||||||
|  |  | ||||||
| Preparing values for use in database lookups | Preparing values for use in database lookups | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| As with value conversions, preparing a value for database lookups is a | As with value conversions, preparing a value for database lookups is a | ||||||
| two phase process. | two phase process. | ||||||
|  |  | ||||||
| .. method:: Field.get_prep_lookup(lookup_type, value) | :meth:`.get_prep_lookup` performs the first phase of lookup preparation: | ||||||
|  | type conversion and data validation. | ||||||
| :meth:`.get_prep_lookup` performs the first phase of lookup preparation, |  | ||||||
| performing generic data validity checks |  | ||||||
|  |  | ||||||
| Prepares the ``value`` for passing to the database when used in a lookup (a | Prepares the ``value`` for passing to the database when used in a lookup (a | ||||||
| ``WHERE`` constraint in SQL). The ``lookup_type`` will be one of the valid | ``WHERE`` constraint in SQL). The ``lookup_type`` parameter will be one of the | ||||||
| Django filter lookups: ``exact``, ``iexact``, ``contains``, ``icontains``, | valid Django filter lookups: ``exact``, ``iexact``, ``contains``, ``icontains``, | ||||||
| ``gt``, ``gte``, ``lt``, ``lte``, ``in``, ``startswith``, ``istartswith``, | ``gt``, ``gte``, ``lt``, ``lte``, ``in``, ``startswith``, ``istartswith``, | ||||||
| ``endswith``, ``iendswith``, ``range``, ``year``, ``month``, ``day``, | ``endswith``, ``iendswith``, ``range``, ``year``, ``month``, ``day``, | ||||||
| ``isnull``, ``search``, ``regex``, and ``iregex``. | ``isnull``, ``search``, ``regex``, and ``iregex``. | ||||||
| @@ -688,17 +652,18 @@ should raise either a ``ValueError`` if the ``value`` is of the wrong sort (a | |||||||
| list when you were expecting an object, for example) or a ``TypeError`` if | list when you were expecting an object, for example) or a ``TypeError`` if | ||||||
| your field does not support that type of lookup. For many fields, you can get | your field does not support that type of lookup. For many fields, you can get | ||||||
| by with handling the lookup types that need special handling for your field | by with handling the lookup types that need special handling for your field | ||||||
| and pass the rest to the :meth:`.get_db_prep_lookup` method of the parent class. | and pass the rest to the :meth:`~Field.get_db_prep_lookup` method of the parent | ||||||
|  | class. | ||||||
|  |  | ||||||
| If you needed to implement ``get_db_prep_save()``, you will usually need to | If you needed to implement :meth:`.get_db_prep_save`, you will usually need to | ||||||
| implement ``get_prep_lookup()``. If you don't, ``get_prep_value`` will be | implement :meth:`.get_prep_lookup`. If you don't, :meth:`.get_prep_value` will | ||||||
| called by the default implementation, to manage ``exact``, ``gt``, ``gte``, | be called by the default implementation, to manage ``exact``, ``gt``, ``gte``, | ||||||
| ``lt``, ``lte``, ``in`` and ``range`` lookups. | ``lt``, ``lte``, ``in`` and ``range`` lookups. | ||||||
|  |  | ||||||
| You may also want to implement this method to limit the lookup types that could | You may also want to implement this method to limit the lookup types that could | ||||||
| be used with your custom field type. | be used with your custom field type. | ||||||
|  |  | ||||||
| Note that, for ``range`` and ``in`` lookups, ``get_prep_lookup`` will receive | Note that, for ``"range"`` and ``"in"`` lookups, ``get_prep_lookup`` will receive | ||||||
| a list of objects (presumably of the right type) and will need to convert them | a list of objects (presumably of the right type) and will need to convert them | ||||||
| to a list of things of the right type for passing to the database. Most of the | to a list of things of the right type for passing to the database. Most of the | ||||||
| time, you can reuse ``get_prep_value()``, or at least factor out some common | time, you can reuse ``get_prep_value()``, or at least factor out some common | ||||||
| @@ -719,21 +684,16 @@ accepted lookup types to ``exact`` and ``in``:: | |||||||
|             else: |             else: | ||||||
|                 raise TypeError('Lookup type %r not supported.' % lookup_type) |                 raise TypeError('Lookup type %r not supported.' % lookup_type) | ||||||
|  |  | ||||||
| .. method:: Field.get_db_prep_lookup(lookup_type, value, connection, prepared=False) | For performing database-specific data conversions required by a lookup, | ||||||
|  | you can override :meth:`~Field.get_db_prep_lookup`. | ||||||
|  |  | ||||||
| Performs any database-specific data conversions required by a lookup. | .. _specifying-form-field-for-model-field: | ||||||
| As with :meth:`.get_db_prep_value`, the specific connection that will |  | ||||||
| be used for the query is passed as the ``connection`` parameter. |  | ||||||
| The ``prepared`` argument describes whether the value has already been |  | ||||||
| prepared with :meth:`.get_prep_lookup`. |  | ||||||
|  |  | ||||||
| Specifying the form field for a model field | Specifying the form field for a model field | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| .. method:: Field.formfield(form_class=None, choices_form_class=None, **kwargs) | To customize the form field used by :class:`~django.forms.ModelForm`, you can | ||||||
|  | override :meth:`~Field.formfield`. | ||||||
| Returns the default form field to use when this model field is displayed in a |  | ||||||
| form.  This method is called by the :class:`~django.forms.ModelForm` helper. |  | ||||||
|  |  | ||||||
| The form field class can be specified via the ``form_class`` and | The form field class can be specified via the ``form_class`` and | ||||||
| ``choices_form_class`` arguments; the latter is used if the field has choices | ``choices_form_class`` arguments; the latter is used if the field has choices | ||||||
| @@ -748,7 +708,8 @@ delegate further handling to the parent class. This might require you to write | |||||||
| a custom form field (and even a form widget). See the :doc:`forms documentation | a custom form field (and even a form widget). See the :doc:`forms documentation | ||||||
| </topics/forms/index>` for information about this. | </topics/forms/index>` for information about this. | ||||||
|  |  | ||||||
| Continuing our ongoing example, we can write the :meth:`.formfield` method as:: | Continuing our ongoing example, we can write the :meth:`~Field.formfield` method | ||||||
|  | as:: | ||||||
|  |  | ||||||
|     class HandField(models.Field): |     class HandField(models.Field): | ||||||
|         # ... |         # ... | ||||||
| @@ -767,15 +728,11 @@ fields. | |||||||
| .. _helper functions: ../forms/#generating-forms-for-models | .. _helper functions: ../forms/#generating-forms-for-models | ||||||
| .. _forms documentation: ../forms/ | .. _forms documentation: ../forms/ | ||||||
|  |  | ||||||
|  | .. _emulating-built-in-field-types: | ||||||
|  |  | ||||||
| Emulating built-in field types | Emulating built-in field types | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| .. method:: Field.get_internal_type() |  | ||||||
|  |  | ||||||
| Returns a string giving the name of the :class:`~django.db.models.Field` |  | ||||||
| subclass we are emulating at the database level. This is used to determine the |  | ||||||
| type of database column for simple cases. |  | ||||||
|  |  | ||||||
| If you have created a :meth:`.db_type` method, you don't need to worry about | If you have created a :meth:`.db_type` method, you don't need to worry about | ||||||
| :meth:`.get_internal_type` -- it won't be used much. Sometimes, though, your | :meth:`.get_internal_type` -- it won't be used much. Sometimes, though, your | ||||||
| database storage is similar in type to some other field, so you can use that | database storage is similar in type to some other field, so you can use that | ||||||
| @@ -796,21 +753,21 @@ storing a string. | |||||||
| If :meth:`.get_internal_type` returns a string that is not known to Django for | If :meth:`.get_internal_type` returns a string that is not known to Django for | ||||||
| the database backend you are using -- that is, it doesn't appear in | the database backend you are using -- that is, it doesn't appear in | ||||||
| ``django.db.backends.<db_name>.creation.data_types`` -- the string will still be | ``django.db.backends.<db_name>.creation.data_types`` -- the string will still be | ||||||
| used by the serializer, but the default :meth:`.db_type` method will return | used by the serializer, but the default :meth:`~Field.db_type` method will | ||||||
| ``None``. See the documentation of :meth:`.db_type` for reasons why this might be | return ``None``. See the documentation of :meth:`~Field.db_type` for reasons why | ||||||
| useful. Putting a descriptive string in as the type of the field for the | this might be useful. Putting a descriptive string in as the type of the field | ||||||
| serializer is a useful idea if you're ever going to be using the serializer | for the serializer is a useful idea if you're ever going to be using the | ||||||
| output in some other place, outside of Django. | serializer output in some other place, outside of Django. | ||||||
|  |  | ||||||
|  | .. _converting-model-field-to-serialization: | ||||||
|  |  | ||||||
| Converting field data for serialization | Converting field data for serialization | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| .. method:: Field.value_to_string(obj) | To customize how the values are serialized by a serializer, you can override | ||||||
|  | :meth:`~Field.value_to_string`. Calling ``Field._get_val_from_obj(obj)`` is the | ||||||
| This method is used by the serializers to convert the field into a string for | best way to get the value serialized. For example, since our ``HandField`` uses | ||||||
| output. Calling ``Field._get_val_from_obj(obj)`` is the best way to get the | strings for its data storage anyway, we can reuse some existing conversion code:: | ||||||
| value to serialize. For example, since our ``HandField`` uses strings for its |  | ||||||
| data storage anyway, we can reuse some existing conversion code:: |  | ||||||
|  |  | ||||||
|     class HandField(models.Field): |     class HandField(models.Field): | ||||||
|         # ... |         # ... | ||||||
| @@ -841,9 +798,8 @@ smoothly: | |||||||
|    Python 2) automatically converts to the string form of your Python object, |    Python 2) automatically converts to the string form of your Python object, | ||||||
|    you can save yourself a lot of work. |    you can save yourself a lot of work. | ||||||
|  |  | ||||||
|  |  | ||||||
| Writing a ``FileField`` subclass | Writing a ``FileField`` subclass | ||||||
| ================================= | ================================ | ||||||
|  |  | ||||||
| In addition to the above methods, fields that deal with files have a few other | In addition to the above methods, fields that deal with files have a few other | ||||||
| special requirements which must be taken into account. The majority of the | special requirements which must be taken into account. The majority of the | ||||||
|   | |||||||
| @@ -7,8 +7,8 @@ Model field reference | |||||||
|  |  | ||||||
| .. currentmodule:: django.db.models | .. currentmodule:: django.db.models | ||||||
|  |  | ||||||
| This document contains all the gory details about all the `field options`_ and | This document contains all the API references of :class:`Field` including the | ||||||
| `field types`_ Django's got to offer. | `field options`_ and `field types`_ Django offers. | ||||||
|  |  | ||||||
| .. seealso:: | .. seealso:: | ||||||
|  |  | ||||||
| @@ -1519,3 +1519,191 @@ accepted by :class:`ForeignKey`, plus one extra argument: | |||||||
|  |  | ||||||
| See :doc:`One-to-one relationships </topics/db/examples/one_to_one>` for usage | See :doc:`One-to-one relationships </topics/db/examples/one_to_one>` for usage | ||||||
| examples of ``OneToOneField``. | examples of ``OneToOneField``. | ||||||
|  |  | ||||||
|  | Field API reference | ||||||
|  | =================== | ||||||
|  |  | ||||||
|  | .. class:: Field | ||||||
|  |  | ||||||
|  |     ``Field`` is an abstract class that represents a database table column. | ||||||
|  |     Django uses fields to create the database table (:meth:`db_type`), to map | ||||||
|  |     Python types to database (:meth:`get_prep_value`) and vice-versa | ||||||
|  |     (:meth:`to_python`), and to apply :doc:`/ref/models/lookups` | ||||||
|  |     (:meth:`get_prep_lookup`). | ||||||
|  |  | ||||||
|  |     A field is thus a fundamental piece in different Django APIs, notably, | ||||||
|  |     :class:`models <django.db.models.Model>` and :class:`querysets | ||||||
|  |     <django.db.models.query.QuerySet>`. | ||||||
|  |  | ||||||
|  |     In models, a field is instantiated as a class attribute and represents a | ||||||
|  |     particular table column, see :doc:`/topics/db/models`. It has attributes | ||||||
|  |     such as :attr:`null` and :attr:`unique`, and methods that Django uses to | ||||||
|  |     map the field value to database-specific values. | ||||||
|  |  | ||||||
|  |     A ``Field`` is a subclass of | ||||||
|  |     :class:`~django.db.models.lookups.RegisterLookupMixin` and thus both | ||||||
|  |     :class:`~django.db.models.Transform` and | ||||||
|  |     :class:`~django.db.models.Lookup` can be registered on it to be used | ||||||
|  |     in ``QuerySet``\s (e.g. ``field_name__exact="foo"``). All :ref:`built-in | ||||||
|  |     lookups <field-lookups>` are registered by default. | ||||||
|  |  | ||||||
|  |     All of Django's built-in fields, such as :class:`CharField`, are particular | ||||||
|  |     implementations of ``Field``. If you need a custom field, you can either | ||||||
|  |     subclass any of the built-in fields or write a ``Field``` from scratch. In | ||||||
|  |     either case, see :doc:`/howto/custom-model-fields`. | ||||||
|  |  | ||||||
|  |     .. attribute:: description | ||||||
|  |  | ||||||
|  |         A verbose description of the field, e.g. for the | ||||||
|  |         :mod:`django.contrib.admindocs` application. | ||||||
|  |  | ||||||
|  |         The description can be of the form:: | ||||||
|  |  | ||||||
|  |             description = _("String (up to %(max_length)s)") | ||||||
|  |  | ||||||
|  |         where the arguments are interpolated from the field's ``__dict__``. | ||||||
|  |  | ||||||
|  |     To map a ``Field`` to a database-specific type, Django exposes two methods: | ||||||
|  |  | ||||||
|  |     .. method:: get_internal_type() | ||||||
|  |  | ||||||
|  |         Returns a string naming this field for backend specific purposes. | ||||||
|  |         By default, it returns the class name. | ||||||
|  |  | ||||||
|  |         See :ref:`emulating-built-in-field-types` for usage in custom fields. | ||||||
|  |  | ||||||
|  |     .. method:: db_type(connection) | ||||||
|  |  | ||||||
|  |         Returns the database column data type for the :class:`Field`, taking | ||||||
|  |         into account the ``connection``. | ||||||
|  |  | ||||||
|  |         See :ref:`custom-database-types` for usage in custom fields. | ||||||
|  |  | ||||||
|  |     There are three main situations where Django needs to interact with the | ||||||
|  |     database backend and fields: | ||||||
|  |  | ||||||
|  |     * when it queries the database (Python value -> database backend value) | ||||||
|  |     * when it loads data from the database (database backend value -> Python | ||||||
|  |       value) | ||||||
|  |     * when it saves to the database (Python value -> database backend value) | ||||||
|  |  | ||||||
|  |     When querying, :meth:`get_db_prep_value` and :meth:`get_prep_value` are used: | ||||||
|  |  | ||||||
|  |     .. method:: get_prep_value(value) | ||||||
|  |  | ||||||
|  |         ``value`` is the current value of the model's attribute, and the method | ||||||
|  |         should return data in a format that has been prepared for use as a | ||||||
|  |         parameter in a query. | ||||||
|  |  | ||||||
|  |         See :ref:`converting-python-objects-to-query-values` for usage. | ||||||
|  |  | ||||||
|  |     .. method:: get_db_prep_value(value, connection, prepared=False) | ||||||
|  |  | ||||||
|  |         Converts ``value`` to a backend-specific value. By default it returns | ||||||
|  |         ``value`` if ``prepared=True`` and :meth:`~Field.get_prep_value` if is | ||||||
|  |         ``False``. | ||||||
|  |  | ||||||
|  |         See :ref:`converting-query-values-to-database-values` for usage. | ||||||
|  |  | ||||||
|  |     When loading data, :meth:`to_python` is used: | ||||||
|  |  | ||||||
|  |     .. method:: to_python(value) | ||||||
|  |  | ||||||
|  |         Converts a value as returned by the database (or a serializer) to a | ||||||
|  |         Python object. It is the reverse of :meth:`get_prep_value`. | ||||||
|  |  | ||||||
|  |         The default implementation returns ``value``, which is the common case | ||||||
|  |         when the database backend already returns the correct Python type. | ||||||
|  |  | ||||||
|  |         See :ref:`converting-database-values-to-python-objects` for usage. | ||||||
|  |  | ||||||
|  |     When saving, :meth:`pre_save` and :meth:`get_db_prep_save` are used: | ||||||
|  |  | ||||||
|  |     .. method:: get_db_prep_save(value, connection) | ||||||
|  |  | ||||||
|  |         Same as the :meth:`get_db_prep_value`, but called when the field value | ||||||
|  |         must be *saved* to the database. By default returns | ||||||
|  |         :meth:`get_db_prep_value`. | ||||||
|  |  | ||||||
|  |     .. method:: pre_save(model_instance, add) | ||||||
|  |  | ||||||
|  |         Method called prior to :meth:`get_db_prep_save` to prepare the value | ||||||
|  |         before being saved (e.g. for :attr:`DateField.auto_now`). | ||||||
|  |  | ||||||
|  |         ``model_instance`` is the instance this field belongs to and ``add`` | ||||||
|  |         is whether the instance is being saved to the database for the first | ||||||
|  |         time. | ||||||
|  |  | ||||||
|  |         It should return the value of the appropriate attribute from | ||||||
|  |         ``model_instance`` for this field. The attribute name is in | ||||||
|  |         ``self.attname`` (this is set up by :class:`~django.db.models.Field`). | ||||||
|  |  | ||||||
|  |         See :ref:`preprocessing-values-before-saving` for usage. | ||||||
|  |  | ||||||
|  |     Besides saving to the database, the field also needs to know how to | ||||||
|  |     serialize its value (inverse of :meth:`to_python`): | ||||||
|  |  | ||||||
|  |     .. method:: value_to_string(obj) | ||||||
|  |  | ||||||
|  |         Converts ``obj`` to a string. Used to serialize the value of the field. | ||||||
|  |  | ||||||
|  |         See :ref:`converting-model-field-to-serialization` for usage. | ||||||
|  |  | ||||||
|  |     When a lookup is used on a field, the value may need to be "prepared". | ||||||
|  |     Django exposes two methods for this: | ||||||
|  |  | ||||||
|  |     .. method:: get_prep_lookup(lookup_type, value) | ||||||
|  |  | ||||||
|  |         Prepares ``value`` to the database prior to be used in a lookup. | ||||||
|  |         The ``lookup_type`` will be one of the valid Django filter lookups: | ||||||
|  |         ``"exact"``, ``"iexact"``, ``"contains"``, ``"icontains"``, | ||||||
|  |         ``"gt"``, ``"gte"``, ``"lt"``, ``"lte"``, ``"in"``, ``"startswith"``, | ||||||
|  |         ``"istartswith"``, ``"endswith"``, ``"iendswith"``, ``"range"``, | ||||||
|  |         ``"year"``, ``"month"``, ``"day"``, ``"isnull"``, ``"search"``, | ||||||
|  |         ``"regex"``, and ``"iregex"``. | ||||||
|  |  | ||||||
|  |         .. versionadded:: 1.7 | ||||||
|  |  | ||||||
|  |         If you are using :doc:`Custom lookups </ref/models/lookups>` the | ||||||
|  |         ``lookup_type`` can be any ``lookup_name`` registered in the field. | ||||||
|  |  | ||||||
|  |         See :ref:`preparing-values-for-use-in-database-lookups` for usage. | ||||||
|  |  | ||||||
|  |     .. method:: get_db_prep_lookup(lookup_type, value, connection, prepared=False) | ||||||
|  |  | ||||||
|  |         Similar to :meth:`get_db_prep_value`, but for performing a lookup. | ||||||
|  |  | ||||||
|  |         As with :meth:`get_db_prep_value`, the specific connection that will | ||||||
|  |         be used for the query is passed as ``connection``. In addition, | ||||||
|  |         ``prepared`` describes whether the value has already been prepared with | ||||||
|  |         :meth:`get_prep_lookup`. | ||||||
|  |  | ||||||
|  |     When using :class:`model forms <django.forms.ModelForm>`, the ``Field`` | ||||||
|  |     needs to know which form field it should be represented by: | ||||||
|  |  | ||||||
|  |     .. method:: formfield(form_class=None, choices_form_class=None, **kwargs) | ||||||
|  |  | ||||||
|  |         Returns the default :class:`django.forms.Field` of this field for | ||||||
|  |         :class:`~django.forms.ModelForm`. | ||||||
|  |  | ||||||
|  |         By default, if both ``form_class`` and ``choices_form_class`` are | ||||||
|  |         ``None``, it uses :class:`~django.forms.CharField`; if | ||||||
|  |         ``choices_form_class`` is given, it returns | ||||||
|  |         :class:`~django.forms.TypedChoiceField`. | ||||||
|  |  | ||||||
|  |         See :ref:`specifying-form-field-for-model-field` for usage. | ||||||
|  |  | ||||||
|  |     .. method:: deconstruct() | ||||||
|  |  | ||||||
|  |         .. versionadded:: 1.7 | ||||||
|  |  | ||||||
|  |         Returns a 4-tuple with enough information to recreate the field: | ||||||
|  |  | ||||||
|  |         1. The name of the field on the model. | ||||||
|  |         2. The import path of the field (e.g. ``"django.db.models.IntegerField"``). | ||||||
|  |            This should be the most portable version, so less specific may be better. | ||||||
|  |         3. A list of positional arguments. | ||||||
|  |         4. A dict of keyword arguments. | ||||||
|  |  | ||||||
|  |         This method must be added to fields prior to 1.7 to migrate its data | ||||||
|  |         using :doc:`/topics/migrations`. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user