Форма Django с выпадающим списком, использующая базу данных, возвращает пустые поля
Я открываю для себя Django и пытаюсь разработать простое приложение.
В моей базе данных есть три таблицы: Одна большая таблица для сообщения всей информации пользователям и 2 таблицы для создания выпадающего списка на моей форме (но без использования внешних ключей специально). Мне нужны эти две таблицы, потому что статусы и области должны быть редактируемыми в любое время и должны быть записаны одинаково каждый раз в главной таблице Action.
Вот мой model.py :
class Status(models.Model):
id_status = models.AutoField(db_column='ID_STATUS', primary_key=True)
status = models.CharField(db_column='STATUS', max_length=50)
def __str__(self):
return self.status
class Meta:
managed = False
db_table = 'T_EAVP_STATUS'
class Area(models.Model):
id_area = models.AutoField(db_column='ID_AREA', primary_key=True)
area_name = models.CharField(db_column='AREA_NAME', max_length=50)
def __str__(self):
return self.area_name
class Meta:
managed = False
db_table = 'T_EAVP_AREA'
class Action(models.Model):
id = models.AutoField(db_column='ID', primary_key=True)
title = models.CharField(db_column='TITLE', max_length=200)
due_date = models.DateTimeField(db_column='DUE_DATE')
status = models.CharField(db_column='STATUS', max_length=50)
date_insert = models.DateTimeField(db_column='DATE_INSERT', auto_now_add=True)
emitting_area = models.CharField(db_column='EMITTING_AREA', max_length=50)
receiving_area = models.CharField(db_column='RECEIVING_AREA', max_length=50)
owner = models.CharField(db_column='OWNER', max_length=200)
def __str__(self):
return self.title
class Meta:
managed = False
db_table = 'T_EAVP_ACTION'
Вот мой forms.py :
class ActionForm(forms.ModelForm):
status = forms.ModelChoiceField(queryset=Status.objects.all())
receiving_area = forms.ModelChoiceField(queryset=Area.objects.all())
emitting_area = forms.ModelChoiceField(queryset=Area.objects.all())
class Meta:
model = Action
fields = ['title', 'due_date', 'owner']
Вот мой views.py :
@csrf_exempt
@xframe_options_exempt
def action_add(request):
if request.method == 'POST':
form = ActionForm(request.POST)
if form.is_valid():
action = form.save()
return redirect('action-list')
else:
form = ActionForm()
return render(request, 'polls/action_add.html', {'form': form})
Вот мой HTML код :
{% extends 'polls/base.html' %}
{% block title %}{{ action.title }}{% endblock %}
{% block content %}
<h1>Ajouter une action</h1>
<form action="" method="post" class="form" novalidation>
{% csrf_token %}
{{ form }}
<br><br>
<input type="submit" class="submit" value="Créer">
</form>
{% endblock %}
Я почти уверен, что импортировал все необходимые библиотеки из Django.
Проблема : Когда я запускаю свой код и пытаюсь создать новое действие с помощью моей ActionForm, оно не работает должным образом. В таблице Action поля, соответствующие полям, заполняемым выпадающими списками, абсолютно пусты.
Таблица Status и таблица Area содержат значения, поэтому проблема возникает не здесь.
Я пробовал много разных вещей, но ничего не работает, и поля всегда пустые в моей базе данных после сохранения формы.
Если кто-то видит решение, мне интересно!
Решением было добавить название полей в form.py :
class ActionForm(forms.ModelForm): # Crée un formulaire se basant sur Action
status = forms.ModelChoiceField(queryset=Status.objects.all())
receiving_area = forms.ModelChoiceField(queryset=Area.objects.all())
emitting_area = forms.ModelChoiceField(queryset=Area.objects.all())
class Meta:
model = Action
fields = ['title', 'due_date', 'owner', 'status', 'receiving_area', 'emitting_area']
Спасибо, Виллем Ван Онсем!