Django добавляет в базу данных с внешним ключом, в то же время показывая информацию из другой модели - PullRequest
0 голосов
/ 09 ноября 2018

Я хочу добавить элементы в свою базу данных (для модели Student), в то же время отображая материалы из другой модели (School) рядом с формой для Student. \

Это models.py

class School(models.Model):
    name = models.CharField(max_length=256)
    principal = models.CharField(max_length=256)
    location = models.CharField(max_length=256)

    def get_absolute_url(self):
        return reverse('basiccbv:detail', kwargs={'pk':self.pk})

    def __str__(self):
        return self.name


class Student(models.Model):
    name = models.CharField(max_length=256)
    age = models.PositiveIntegerField(validators= [validators.MinValueValidator(1),validators.MaxValueValidator(20)],default=1)
    school = models.ForeignKey(School, related_name='students')

def __str__(self):
    return self.name

В моем views.py у меня есть это:

class SchoolDetailedView(DetailView):
    context_object_name = 'school_detail'
    model = models.School
    template_name = 'basiccbv/school_detail.html'
    # What i want is when I visit the link in the description I want to
    # to see the school stuff and the form to add the student in this new 
    # view

class StudentCreateView(CreateView):
    model = models.School
    # I tried using the Student but that I don't know how to display the 
    # school information, I tried with related_name = 'students' but it 
    # didn't work(I don't know if that can be done the way that intended it 
    # or I just don't have the knowledge )  
    fields = ['name', 'age']
    # If I use School I could get the name of the school in the title and 
    # its primary key, but than I don't know how to display the form and 
    # vise versa 
    template_name = 'basiccbv/student_update.html'

Это файл .html, который доставляет меня на страницу, где мне нужна форма. Ссылка называется basiccbv: studentupdate. Студенты related_name были использованы здесь, но я все еще не могу понять, если это может быть сделано для добавления материала, как я хочу

<h1>Welcome to the school details page</h1>
<h2>School details:</h2>
<p>Name: {{ school_detail.name }}</p>
<p>Principal: {{ school_detail.principal }}</p>
<p>Location: {{ school_detail.location }}</p>
<h3>Students:</h3>
{% for student in school_detail.students.all %}
<p>{{ student.name }} who is {{ student.age }} years old.</p>
{% endfor %}
<div class="container">
<p><a href="{% url 'basiccbv:studentupdate' pk=school_detail.pk %}">Add a 
student</a></p>

А вот и файл .html с формой

              ## I changed this part bellow but nothing worked
<h1>Student coming to {{ student.school.name }}</h1>
<form method="post">
{% csrf_token %}
{{ form.as_p }}
    <input type="submit" class="btn btn-primary" value="Add student">
</form>

Я действительно застрял и не могу найти никакой информации об этом, но если вы можете мне помочь или дать какой-либо совет, спасибо.

Я обычно добавлял студентов с помощью администратора, а для школ я использовал администратор, пока не создал представление для создания школ, которые работали без проблем (возможно, потому что не было внешних ключей).

1 Ответ

0 голосов
/ 09 ноября 2018

Я думаю, что вы можете принять этот подход

Форма:

# We need to define a new form first
class StudentForm(forms.ModelForm):
     class Meta:
         model = Student
         fields = ['name', 'age']

Просмотров:

# we are using form view for using the form mentioned above
class StudentCreateView(FormView):
     form_class = StudentForm
     success_url = "/"

     def get(self, request, school_id, **kwargs):
         context = self.get_context_data(**kwargs)  # getting context, ie: the form
         context[school] = School.objects.get(pk=school_id)  # updating the context with school object using the PK provided with the url
         return self.render_to_response(context)

     def post(self, request, school_id, **kwargs):
        # overriding default implementation
        form = self.get_form()  
        if form.is_valid():
            return self.form_valid(form, school_id)  # passing the pk value to form valid function to override
        else:
            return self.form_invalid(form)

    def form_valid(self, form, school_id):
        # overriding default implementation
        self.object = form.save(commit=False)
        self.object.school = School.objects.get(id=school_id)  # saving the school information to the object
        self.object.save()
        return super(StudentCreateView, self).form_valid(form)

Template

# template
    <h1>Student coming to {{ school.name }}</h1>
    <form method="post">
    {% csrf_token %}
    {{ form.as_p }}
        <input type="submit" class="btn btn-primary" value="Add student">
    </form>

Urls

path('school/student-update/<int:school_id>/', StudentCreateView.as_view(), name='studentupdate'),
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...