django modelformse批量编辑 查询学生班级成绩
复习先知
关于三张表的编辑学生成绩
在跨表查询的对象查询种,只能通过找到两张表的关联的对象,
进行跨表,就是在一对多或多对多的模型找到他们俩的class_id或student_id
在关联时,会通过他们找到所要查询的id,或字段,进而找到他们的字段
进而查询出对象,这个表的对象, .出来
在这种跨三表的途中,编辑跟添加同理.都是通过过
过滤出你要找到学生的对象 学生成绩关联班级成绩 班级成绩关联班级 班级关联学生
这就是这张表的精髓 关于modelformset 可以省去复杂跨表的骚操作
也可以一次性多删除
第一步
引入from django.forms.models import modelformset_factory modelformset_factory(含2个变量,还有一个默认为1)
model() modelform() extra=1
1.实例化对象
2.找到点击的对象 queryset对象
3.实例化对象的方法(queryset=queryset)
返回给页面 自动给你
页面: 一样 但需要标注{{formset.management_form}} 在编辑时候,
1.实例化对象modelformset_factory()
2.formset(request.post)
3.if formset.is_valid() form的通病
4.formset.save()
复杂版
将字段设置联合唯一
class Meta:
unique_together=["student","classstudyrecord"]
class ClassStudyRecordView(View):
def get(self,request):
ClassStudyRecordlist=ClassStudyRecord.objects.all()
return render(request,"ClassStudyRecord.html",{"ClassStudyRecordlist":ClassStudyRecordlist}) def post(self, request):
print(request.POST)
func_st = request.POST.get("action")
num = request.POST.getlist("selected_pk_list") print("num", num)
if not hasattr(self, func_st):
return HttpResponse("非法输入")
else:
func = getattr(self, func_st)
queryset = ClassStudyRecord.objects.filter(pk__in=num) print("queryset", queryset)
ret = func(request, queryset)
if ret:
return ret
return redirect(request.path)
#批量删除
def patch_delete(self, request, queryset):
queryset.delete()
#批量查询,利用跨表查询查询创建字段,为了避免添加重复使用联合唯一
def patch_choice(self,request,queryset):
try:
for i in queryset:
for item in i.class_obj.student_set.all():
StudentStudyRecord.objects.create(student=item,classstudyrecord=i)
except Exception as e:
pass
views.py
跳转页面进行编辑,通过获取form的值构成列表循环录入成绩
def buhui(request,id):
if request.method=="GET":
ret=StudentStudyRecord.objects.filter(classstudyrecord_id=id)
return render(request,"student_std.html",locals())
else:
user = request.POST.getlist("user")
homework = request.POST.getlist("homework")
for a,item in enumerate(ClassStudyRecord.objects.filter(pk=id).first().class_obj.student_set.all()):
print(a,item)
StudentStudyRecord.objects.filter(student=item).update(score=user[a],homework_note=homework[a])
return redirect(request.path)
views.py录入成绩
<table>
<form action="" method="post">
{% csrf_token %}
<thead>
<tr> <th>编号</th>
<th>姓名</th>
<th>考勤</th>
<th>成绩</th>
<th>批语</th> </tr>
</thead>
<tbody> {% for consult_record in ret %}
<tr>
<td>{{ forloop.counter }}</td>
<td>{{ consult_record.student }}</td>
<td>{{ consult_record.get_record_display }}</td>
<td><select name="user" id="">
{% for foo in consult_record.score_choices %}
#进行判断,若是存在值添加selected让其显示,没有显示默认
{% if consult_record.score == foo.0 %}
<option selected value="{{ foo.0 }}">{{ foo.1 }}</option>
{% else %}
<option value="{{ foo.0 }}">{{ foo.1 }}</option>
{% endif %}
{% endfor %}
<option value=""></option>
</select>
</td>
<td><input type="text" name="homework" value="{{ consult_record.homework_note }}"></td>
</tr>
{% endfor %} </tbody>
<button class="btn btn-default">提交</button> </form>
</table>
前端.html
modelformset 简单版
1.首先引入模块
from django.forms.models import modelformset_factory
2.
后端
from django.forms.models import modelformset_factory class StudentStudyRecordModelForm(forms.ModelForm):
class Meta:
model=StudentStudyRecord
fields=["score","homework_note"] class RecordScoreView(View): def get(self, request,class_study_record_id):
#modelformset_factory()里面需要2个变量,model和modelform,extra默认为1,显示添加
model_formset_cls=modelformset_factory(model=StudentStudyRecord,form=StudentStudyRecordModelForm,extra=0)
queryset = StudentStudyRecord.objects.filter(classstudyrecord=class_study_record_id)
formset = model_formset_cls(queryset=queryset)
return render(request,"student/record_score.html",locals()) def post(self, request,class_study_record_id):
model_formset_cls = modelformset_factory(model=StudentStudyRecord, form=StudentStudyRecordModelForm, extra=0)
queryset = StudentStudyRecord.objects.filter(classstudyrecord=class_study_record_id)
print("request.POST",request.POST)
formset=model_formset_cls(request.POST)
if formset.is_valid():
formset.save() print(formset.errors) return redirect(request.path)
modelformset 批量编辑
3.
前端
<hr> <div class="panel panel-default">
<div class="panel-heading">学习记录</div>
<div class="panel-body">
<div style="width: 680px;margin: 0 auto;">
<form method="post" action="">
{% csrf_token %}
#这个必须要写
{{ formset.management_form }} <table class="table table-bordered">
<thead>
<tr>
<th>姓名</th>
<th>考勤</th>
<th>作业成绩</th>
<th>作业评语</th>
</tr>
</thead>
<tbody>
{% for form in formset %}
<tr>
{{ form.id }}
#form.instance.为显示界面,不添加编辑页面
<td>{{ form.instance.student }}</td>
<td>{{ form.instance.get_record_display }} </td>
<td>{{ form.score }} </td>
<td>{{ form.homework_note }}</td>
</tr>
{% endfor %}
</tbody>
</table>
<input type="submit" value="保存">
</form>
</div>
</div>
</div>
<hr>
前端.html
django modelformse批量编辑 查询学生班级成绩的更多相关文章
- SQL 查询:查询学生平均成绩
编程萌新,因为遇到这么个SQL 查询的问题:在一张表A里有如下字段:学生姓名.学科名.学科成绩.写一条SQL 语句查出各科平均成绩并按学生姓名分组,按如下格式显示:学生姓名|语文|数学|英语.一开始遇 ...
- mysql 查询每个班级成绩前两名
- sql-hive笔试题整理 1 (学生表-成绩表-课程表-教师表)
题记:一直在写各种sql查询语句,最长的有一百多行,自信什么需求都可以接,可......,想了想,可能一直在固定的场景下写,平时也是以满足实际需求为目的,竟不知道应试的题都是怎么出的,又应该怎么做.遂 ...
- SQL使用子查询,查找班级成绩最高分
-- 根据要求,获取班级成绩的最高分的学生-- 第一个子查询,先去各个科目的最高,再横向比较各个科目的最高,再取最高分的那个科目-- 第二个子查询,查询每个同学的最高分-- 最后,通过第一个子查询查询 ...
- 《MySQL数据操作与查询》- 维护学生信息、老师信息和成绩信息 支持按多种条件组合查询学生信息和成绩信息
综合项目需求 一.系统整体功能 系统需支持以下功能: 维护学生信息.老师信息和成绩信息 支持按多种条件组合查询学生信息和成绩信息 学生 Student(id,班级id,学号,姓名,性别,电话,地址,出 ...
- Django ORM多表查询练习
ORM多表查询 创建表结构: from django.db import models # 创建表结构 # Create your models here. class Class_grade(mod ...
- Django聚合与分组查询中value与annotate的顺序问题
在学习Django聚合与分组查询中,发现value与annotate的顺序不同时,查询结果大相径庭,经过一下午的研究,终于弄明白了,现在分享给大家,先上结论: 结论 value在annotate前面时 ...
- Django的ORM常用查询操作总结(Django编程-3)
Django的ORM常用查询操作总结(Django编程-3) 示例:一个Student model: class Student(models.Model): name=models.CharFiel ...
- Django框架 之 ORM查询操作详解
Django框架 之 ORM查询操作详解 浏览目录 一般操作 ForeignKey操作 ManyToManyField 聚合查询 分组查询 F查询和Q查询 事务 Django终端打印SQL语句 在Py ...
随机推荐
- Linux性能优化实战学习笔记:第三十讲
一.性能指标 二.文件系统I/O性能指标 1.存储空间的使用情况 文件系统向外展示的空间使用,而非磁盘空间的真是用量,因为文件系统的元数据也会占用磁盘空间 2.索引节点的使用情况 如果存储过多的小文件 ...
- Django-Debug-Toolbar插件
目录 django配置插件: 介绍: 安装及配置: 优化ORM: django配置插件: ---配置Django-Debug-Toolbar 介绍: Django-Debug-Toolbar是项目开发 ...
- [LeetCode] 4. Median of Two Sorted Arrays 两个有序数组的中位数
There are two sorted arrays nums1 and nums2 of size m and n respectively. Find the median of the two ...
- 教你查阅Java API 英文文档(JDK 11)
JAVA Document:https://docs.oracle.com/en/java/javase/11/ 然后找到“Specifications”并点击 API Documentation 比 ...
- Java Web 之 SSM笔记
好久没有写博文了呀呀呀........博客园的MarkDown还是...算了吧 自定义 Restful 风格结果集 参考资料 [SpringBoot专题]统一异常处理和统一数据返回前言实践运行结果 如 ...
- Gitea 使用方法
安装部分笔记 创建专用数据库及用户 create database if not exists gitea default charset = utf8mb4; grant ALL PRIVILEGE ...
- 热情组——项目冲刺 Day5
项目相关 作业相关 具体描述 班级 班级链接 作业要求 链接地址 团队名称 热情组 作业目标 实现软件制作,以及在福大的传播 Github链接 链接地址 SCRUM部分: 成员昵称 昨日目标 开始时间 ...
- PS:老权限登录Action 中 WebObjManager有问题,一直登录不起问题
.ashx后面代码要多继承一个, IRequiresSessionState接口
- swiper轮播,添加鼠标移入事件停止轮播,移出重新开启轮播
已测过无问题.
- 微信小程序常用样式汇总
本文系转载: 原文作者:chenzheng8975 原文地址:https://www.cnblogs.com/chenzheng8975/p/9605186.html 微信小程序常用样式汇总 小程序特 ...