[Django]-Overriding methods for defining custom model field in django

9👍

I’ll try to answer them:

Q: When deconstruct() is used ?

A: This method is being used when you have instance of your Field to re-create it based on arguments you just passed in __init__.
As they mentioned in docs, if you are setting max_length arg to a static value in your __init__ method; you do not need it for your instances. So you can delete it in your deconstruct() method. With this, max_length won’t show up in your instance while you are using it in your models. You can think deconstruct as a last clean-up and control place before use your field in model.


Q: Difference between db_type() and get_internal_type()

A: They are both related, but belong to different levels.

If your custom field’s data type is depends on which DB you are using, db_type() is the place you can do your controls. Again, like they mentioned in docs, if your field is a kind of date/time value, you should / may check if current database is PostgreSQL or MySQL in this method. Because while date/time values called as timestamp in PostgreSQL, it is called datetime in MySQL.

get_internal_type method is kind of higher level version of db_type(). Let’s go over date/time value example: If you don’t want to check and control each data types belongs to different databases, you can inherit your custom field’s data type from built-in Django fields. Instead of checking if it should be datetime or timestamp; you can return simply DateField in your get_internal_type method. As they mentioned in docs, If you’ve created db_type method already, in most cases, you do not need get_internal_type method.


Q: Difference between get_prep_value() and get_db_prep_value()

A: These guys also share almost same logic between db_type() and get_internal_type(). First of all, both these methods stands for converting db values to python objects. But, like in db_type method, get_db_prep_value() stands for backend specific field types.


Q: Difference between value_from_object() and value_to_string(). value_from_object() is not given in docs

A: From the docs:

To customize how the values are serialized by a serializer, you can
override value_to_string(). Using value_from_object() is the best way
to get the field’s value prior to serialization.

So, Actually we don’t need value_from_object as documented. This method is used to get field’s raw value before serialization. Get the value with this method, and customize how it should be serialized in value_to_string method. They even put an example code in docs


Q: Both from_db_value(), value_to_string() and to_python() gives python object from string. Then, why these different methods are exists ?

A: While to_python() converts field value to a valid python object, value_to_string() converts field values to string with your custom serialization. They stands for different jobs.

And from_db_value converts the value returned by database to python object. Never heard of it actually. But check this part from docs:

This method is not used for most built-in fields as the database
backend already returns the correct Python type, or the backend itself
does the conversion.

Leave a comment