1
0
mirror of https://github.com/django/django.git synced 2025-10-25 06:36:07 +00:00

Used backend vendors in custom model fields docs.

This commit is contained in:
Mariusz Felisiak
2021-08-24 16:16:44 +02:00
committed by GitHub
parent b263f4b69d
commit d7394cfa13

View File

@@ -394,13 +394,14 @@ 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``. You can handle this in a :meth:`~Field.db_type` method by ``datetime``. You can handle this in a :meth:`~Field.db_type` method by
checking the ``connection.settings_dict['ENGINE']`` attribute. checking the ``connection.vendor`` attribute. Current built-in vendor names
are: ``sqlite``, ``postgresql``, ``mysql``, and ``oracle``.
For example:: For example::
class MyDateField(models.Field): class MyDateField(models.Field):
def db_type(self, connection): def db_type(self, connection):
if connection.settings_dict['ENGINE'] == 'django.db.backends.mysql': if connection.vendor == 'mysql':
return 'datetime' return 'datetime'
else: else:
return 'timestamp' return 'timestamp'