博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ORM版学员管理系统2
阅读量:5091 次
发布时间:2019-06-13

本文共 3817 字,大约阅读时间需要 12 分钟。

学生信息管理

展示学生信息

URL部分

url(r'^student_list/', app01_views.student_list, name="student_list"),

视图部分

def student_list(request):    student_list = models.Student.objects.all()    return render(request, "student_list.html", {
"student_list": student_list})

前端部分

  
学生列表添加学生
{% for student in student_list%}
{% endfor %}
# id 学生姓名 学生班级 开班日期 操作
{
{ forloop.counter}}
{
{ student.id }}
{
{ student.sname }}
{
{ student.cid.cname }}
{
{ student.cid.first_day|date:'Y-m-d' }}
删除 编辑

删除学生信息

URL部分

url(r'^delete_student/(?P
\d+)$', app01_views.delete_student, name="delete_student"),

视图部分

def delete_student(request, sid):    models.Student.objects.filter(id=sid).delete()    return redirect(reverse("student_list"))

前端部分

添加学生信息

URL部分

url(r'^add_student/$', app01_views.add_student, name="add_student"),

视图部分

def add_student(request):    if request.method == "POST":        sname = request.POST.get("sname")        class_id = request.POST.get("class_id")        models.Student.objects.create(sname=sname, cid_id=class_id)        return redirect(reverse("student_list"))    class_list = models.Class.objects.all()    return render(request, "add_student.html", {
"class_list": class_list})

前端部分

  
添加学生
{% csrf_token %}

学生姓名:

编辑学生信息

URL部分

url(r'^edit_student/(?P
\d+)$', app01_views.edit_student, name="edit_student"),

视图部分

def edit_student(request, sid):    # 获取到编辑的学生对象    student_obj = models.Student.objects.get(id=sid)    # 获取所有的班级数据    class_list = models.Class.objects.all()    if request.method == "POST":        sname = request.POST.get("sname")        class_id = request.POST.get("class_id")        student_obj.sname = sname        student_obj.cid_id = class_id        student_obj.save()        return redirect(reverse("student_list"))    return render(request, "edit_student.html", {
"student": student_obj, "class_list": class_list})

前端部分

  
编辑学生信息
{% csrf_token %}

学生姓名:

 

基于对象的跨表查询

一对多查询(班级表和学生表)

正向查询(由学生表查询班级表)

查询学生的班级信息

>>> student_obj = models.Student.objects.first()>>> student_obj.cid  # 通过model类中的属性查找到对应的外键数据对象
>>> student_obj.cid.cname'1班'>>> student_obj.cid_id # 获取实际外键的值1

反向查询(由班级表查询学生表)

查询班级的学生信息

>>> class_obj = models.Class.objects.first()  # 获取第一个班级对象>>> class_obj.student_set.all()  # 通过表名_set反向查询出所有的学生
,
]>

注意:

如果不在外键的字段中设置related_name的话,默认就用表名_set。

如果设置了related_name="students",反向查询时可直接使用students进行反向查询。

>>> class_obj.students.all()

一对一查询

表结构设计

class Student(models.Model):    sname = models.CharField(max_length=32, verbose_name="学生姓名")    the_class = models.ForeignKey(to=Class, to_field="id", on_delete=models.CASCADE, related_name="students")    detail = models.OneToOneField(to="StudentDetail", null=True)class StudentDetail(models.Model):    height = models.PositiveIntegerField()    weight = models.PositiveIntegerField()    email = models.EmailField()

正向查询(由学生信息表查询学生详情表)

>>> student_obj = models.Student.objects.first()>>> student_obj.detail.email'1@1.com'

反向查询(由学生详情表反向查询学生信息表)

>>> detail_obj = models.StudentDetail.objects.get(id=1)>>> detail_obj.student.sname'a'

 

转载于:https://www.cnblogs.com/liwenzhou/p/8330550.html

你可能感兴趣的文章
STL 案例分析
查看>>
[ActionScript 3.0] AS3 双A字模型
查看>>
后台管理项目简单小总结------彭记(021)
查看>>
死磕JDK源码之Thread
查看>>
jekyll 安装 ...
查看>>
微信页面关于点击按钮关注公众号放到链接里无关注按钮
查看>>
python 字典处理的一些坑
查看>>
构建oracle12c的Docker镜像
查看>>
用户权限命令(chmod,chown,umask,lsattr/chattr)
查看>>
Maven详解
查看>>
Linux系统中‘dmesg’命令处理故障和收集系统信息的7种用法
查看>>
数据结构 : Hash Table [II]
查看>>
面向对象的小demo
查看>>
获取地址栏参数
查看>>
Yale CAS + .net Client 实现 SSO 的完整版
查看>>
java之hibernate之helloworld
查看>>
微服务之初了解(一)
查看>>
Iterator invalidation(迭代器失效)
查看>>
GDOI DAY1游记
查看>>
中介者模式
查看>>