首页 > 解决方案 > django修改数据库对象

问题描述

我正在开发一个考勤管理系统。我想修改学生的出勤率。

class Subject(models.Model):
    subject_name = models.CharField(max_length=20)
    #attendance = models.ForeignKey(Attendance, on_delete = models.DO_NOTHING)
    attendance = models.IntegerField(default=0)
    def __str__(self):
        return self.subject_name


class Section(models.Model):
    section_name = models.CharField(max_length=20)
    subject = models.ManyToManyField(Subject)
    def __str__(self):
        return self.section_name


class Student(models.Model):
    rollno = models.IntegerField()
    name = models.CharField(max_length=20)
    section = models.ForeignKey(Section, on_delete = models.DO_NOTHING, default=0)
    def __str__(self):
        return str(self.rollno) + self.name 

这是我的模板。(学生.html)

{% for i in data %}  
                <tr>
                    <td>{{ i.rollno }}</td>
                    <td>{{ i.name }}</td>
                    <td> <button class='btn btn-danger' id='{{i.rollno}}' on click = "{{ i.section.subject.get(subject_name='java').attendance)|add:1 }}"> 
                    </td>
                </tr>
{% endfor %}

我在模板中使用 .get() 方法时出错。我想通过单击按钮添加(+1)出席。

标签: pythondjangotemplatesmodels

解决方案


我强烈建议阅读Django Tutorial。您将学习 Django MVC 概念并能够轻松实现您的要求。下面的代码将帮助您入门。

视图.py

def increment_attendance(request, subject_id):
  """Increment Attendance for a Subject"""

    subject = Subject.objects.get(id=subject_id)
    # check if record exists
    if not subject:
        raise Http404("Invalid subject_id")

    # can also use only get_object_or_404(Subject, pk=subject_id)

    # increment attendance
    subject.attendance += 1
    # save / commit to database
    subject.save()

    # redirec to 'some' page or previous page?
    return redirect('top')

将此路径添加到您的 urls.py

  path('subject/<int:day>/increment_attendance', views.increment_attendance, name='increment_attendance')

模板

  <a class="btn btn-danger" id="{{i.rollno}}" href="{% url 'increment_attendance' subject_id=subject_id" %}"></a>

推荐阅读