python - 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)出席。
解决方案
我强烈建议阅读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>
推荐阅读
- powershell - PowerShell Where-Object 查询括号之间的空或 NULL 内容
- spring - 处理对 Spring Rest Controller 的同时 HTTP 调用
- python - 从嵌套列表中的子列表中提取第一个和最后一个元素
- asp.net-mvc - 剑道编辑器模板可见条件
- javascript - 在渲染中获取数据,但是在显示时,什么都没有出现
- html - 如何在页面内添加一个正方形(大约 80% 的宽度和高度以及彩色)?
- php - 无法在 Symfony 5.1 中安装 orm-pack
- flutter - Flutter Bad state:调用close后无法添加新事件
- elasticsearch - 如何使用 S3 为 EFK 堆栈配置日志的长期保留?
- html - 如何排除css中的特定类?