Я работаю с устаревшей таблицей Postgresql и обнаружил, что некоторые поля имеют типы данных обычай.
Например, вместо, например. character varying, столбец color имеет тип данных color_type с допустимыми параметрами [red|green|blue|black].
В зависимости от команды inspectdb автоматически сгенерированная модель содержит следующую строку и комментарий:
color = models.TextField(blank=True, null=True) # This field type is a guess.
Я бы «очистил» эту строку, как описано в следующем классе, но не уверен, а) будет ли она правильно «подходить» к существующей таблице (например, если я пишу новые объекты внутри таблицы), и б) будет ли перенос в новая база данных, custom_type будет правильно воспроизведен:
class Things(models.Model):
name = models.CharField(max_length=30, null=True, blank=True)
RED = 'red'
GREEN = 'green'
BLUE = 'blue'
BLACK= 'black'
COLOR_CHOICES = (
(RED, 'red'),
(GREEN, 'green'),
(BLUE, 'blue'),
(BLACK, 'black'),
)
color = models.CharField(
max_length = 10,
choices = COLOR_CHOICES,
default = RED,
null = True,
blank = True
)
def __str__(self):
return self.name
class Meta:
managed = False
db_table = 'myuser'
Как правильно отразить этот пользовательский тип данных в модели Django?





Вы можете написать Пользовательское поле, который использует определенный пользователем тип базы данных:
class ColorField(models.Field):
def db_type(self, connection):
return 'enum("red","green","blue","black")'
Да, вы можете, общие параметры поля, доступные для всех типов полей, перечислены здесь docs.djangoproject.com/en/2.1/topics/db/models/#field-options
Спасибо, пропустил эту часть в документах! Не могли бы вы также уточнить, могу ли я безопасно написать
color = ColorField(null = True, blank = True), то есть передать обычные аргументы в класс пользовательского поля?