一、功能:

  1. 实现对学生对个人信息的增删查改
  2. 实现后台对所有学生信息的操作

二、此后台采用的是MVC的风格模式进行编码

1.VIEWS部分

from django.http import HttpResponse
from django.shortcuts import render
from .models import Student, OneClass # from django.http import request
# Create your views here.
def index(request):
return render(request, 'index.html') def add(request):
name = request.GET.get('name')
age = request.GET.get('age')
learn = request.GET.get('learn')
type1 = request.GET.get('type1')
# type 为1表示执行数据库操作,否则只是跳转页面
if type1 == '1':
Student.objects.create(name=name, age=age, learn=learn) # 在student 表里新建一条记录
# return render(request, 'add.html',)
return render(request, 'add.html') def delete(request):
name = request.GET.get('name')
type1 = request.GET.get('type1')
# type 为 1 表示执行数据库查询操作
# if type1 == '1':
# # 查询所在记录
# try:
# stu: Student = Student.objects.filter(name=name).get()
# except Exception:
# return HttpResponse("无此记录")
# return render(request, 'delete.html', {'stu': stu})
# type 为 2 表示执行数据库确认删除操作
if type1 == '2':
try:
Student.objects.filter(name=name).get()
except Exception:
return HttpResponse("无此记录")
Student.objects.filter(name=name).delete() # 按照姓名, 进行过滤
return render(request, 'delete.html', {'msg': '删除成功'})
return render(request, 'delete.html') def update(request):
name = request.GET.get('name')
age = request.GET.get('age')
learn = request.GET.get('learn')
type1 = request.GET.get('type1')
# type 为1表示执行数据库操作,否则只是跳转页面
if type1 == '1':
try:
stu = Student.objects.get(name=name)
stu.name = name
stu.age = age
stu.learn = learn
stu.save()
return render(request, "update.html", {'msg': '修改成功'})
except Exception:
return HttpResponse("无此记录")
return render(request, 'update.html') def query(request):
name = request.GET.get('name')
type1 = request.GET.get('type1')
# type 为1表示执行数据库操作,否则只是跳转页面
if type1 == '1':
if name == 'all':
stu_list = Student.objects.all()
return render(request, 'query.html', {'stu_list': stu_list})
try:
Student.objects.filter(name=name).get()
except Exception:
return HttpResponse("无此记录")
stu = Student.objects.get(name=name) # 在student 表里查询一条记录
return render(request, 'query.html', {'stu': stu}) return render(request, 'query.html')

2.MODELS 部分

from django.db import models

# Create your models here.
# 学生类模板
class Student(models.Model):
name = models.CharField(max_length=20)
age = models.IntegerField()
learn = models.CharField(max_length=20) # 教师类模板
class Teacher(models.Model):
name = models.CharField(max_length=20)
age = models.IntegerField()
teach = models.CharField(max_length=20)
student = models.ManyToManyField(Student, through="OneClass") # 班级类模板
class OneClass(models.Model):
name = models.CharField(max_length=50)
teacher = models.ForeignKey('Teacher', on_delete=models.CASCADE)
student = models.ForeignKey('Student', on_delete=models.CASCADE)

  

3.CONTROLLER部分

  • URL配置
from django.conf.urls import url
from . import views urlpatterns=[
url(r'^index', views.index),
url(r'^add', views.add),
url(r'^delete', views.delete),
url(r'^query', views.query),
url(r'^update', views.update)
]

  

五、功能展示 
1.主界面(功能选择)

2.增加学生信息

3.查询学生信息

4.删除学生信息

作者:含笑半步颠√

博客链接:https://www.cnblogs.com/lixy-88428977

声明:本文为博主学习感悟总结,水平有限,如果不当,欢迎指正。如果您认为还不错,欢迎转载。转载与引用请注明作者及出处。

django学习_学生信息管理后台的更多相关文章

  1. django学习-22.admi管理后台页面的文案展示等相关配置

    目录结果 1.前言 2.完整的操作步骤 2.1.第一步:对[settings.py]里的相关常量的值做如下修改 2.2.第二步:重启django项目[helloworld]的服务 2.3.第三步:重新 ...

  2. django学习-19.admin管理后台的配置和登录

    目录结构 1.前言 2.admin管理后台的配置和登录的完整操作流程 2.1.第一步: 在[settings.py]里对常量[INSTALLED_APPS]的值进行相关配置 2.2.第二步: 在[ur ...

  3. Django学习:创建admin后台管理站点

    Django自带一个后台管理站点,方便我们管理数据.这个界面只给管理员使用,并不对大众开放. 创建管理员用户 py manage.py createsuperuser 如下图所示: 用户名不填的话,默 ...

  4. django学习-26.admin管理后台里:修改登录页面标题,修改登录框标题,修改首页标题

    目录结构 1.前言 2.完整的操作步骤 2.1.第一步:查看[site.py]的源码 2.2.第二步:在应用[hello]所在目录里的[admin.py]里重写三个属性的属性值 2.3.第三步:重启服 ...

  5. django学习-25.admin管理后台里:把表名称和表字段名称的展示值都由英文显示改为由中文显示

    目录结构 1.前言 2.完整的操作步骤 2.1.第一步:修改模型类Article 2.2.第二步:重启服务 2.3.第三步:退出登录并再次成功登陆admin管理后台 2.4.第四步:查看最新的表名称展 ...

  6. django学习-23.admin管理后台的数据表数据的自定义展示

    目录结构 1.前言 2.自定义设置一张指定的数据表的列表展示内容 2.1.第一步:如果我们想让数据表[hello_person]里面的表字段值全部展示出来,需在应用[hello]里的[admin.py ...

  7. django学习-27.admin管理后台里:对列表展示页面的数据展示进行相关优化

    目录结构 1.前言 2.完整的操作步骤 2.1.第一步:查看ModelAdmin类和BaseModelAdmin类的源码 2.2.第二步:查看表animal对应的列表展示页面默认的数据展示 2.3.第 ...

  8. python学习_数据处理编程实例(二)

    在上一节python学习_数据处理编程实例(二)的基础上数据发生了变化,文件中除了学生的成绩外,新增了学生姓名和出生年月的信息,因此将要成变成:分别根据姓名输出每个学生的无重复的前三个最好成绩和出生年 ...

  9. Django学习-1-管理我的django程序

    网页中文文档 http://python.usyiyi.cn/documents/django_182/topics/db/models.html Django性能测试工具 https://githu ...

随机推荐

  1. postgresql 相关函数总结

    1.获取当前日期的年份 select to_char(t.detect_date,'YYYY') select extract(year from now())为double precision 格式 ...

  2. Java并行程序基础。

    并发,就是用多个执行器(线程)来完成一个任务(大任务)来处理业务(提高效率)的方法.而在这个过程中,会涉及到一些问题,所以学的就是解决这些问题的方法. 线程的基本操作: 1.创建线程:只需要new一个 ...

  3. Centos 7 修改网卡名称、静态IP

    修改内核选项 # vim /etc/sysconfig/grub GRUB_TIMEOUT= GRUB_DISTRIBUTOR="$(sed 's, release .*$,,g' /etc ...

  4. 爬虫---Beautiful Soup 反反爬虫事例

    前两章简单的讲了Beautiful Soup的用法,在爬虫的过程中相信都遇到过一些反爬虫,如何跳过这些反爬虫呢?今天通过知乎网写一个简单的反爬中 什么是反爬虫 简单的说就是使用任何技术手段,阻止别人批 ...

  5. Python 函数小程序初解

    目录 作业 ==程序代码自上往下运行,建议自上而下的完成下列任务== 作业 文件a.txt内容:每一行内容分别为商品名字,价钱,个数,求出本次购物花费的总钱数 sum = 0 f = open('a. ...

  6. 201871010109-胡欢欢《面向对象程序设计(java)》第十一周学习总结

    项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-daizh/p ...

  7. django学习-视图练习

    写一个真正有用的视图 每个视图必须要做的只有两件事: 返回一个包含被请求页面内容的HttpResponse对象,或抛出一个异常,比如Http404. 至于你还想干些什么,随便你. 你的视图可以从数据库 ...

  8. Docker容器数据卷(七)

    Docker致力于: 将运用与运行的环境打包形成容器运行 ,运行可以伴随着容器,但是我们对数据的要求希望是持久化的 容器之间希望有可能共享数据 Docker容器产生的数据,如果不通过docker co ...

  9. 洛谷 U87052 一线天

    洛谷 U87052 一线天 题目传送门 题目背景 \(JDFZ\)即将举办第一届"一线天"趣味运动会...... 题目描述 "一线天"运动会在\(JLU\)南岭 ...

  10. USACO Cow Cars

    洛谷 P2909 [USACO08OPEN]牛的车Cow Cars https://www.luogu.org/problemnew/show/P2909 JDOJ 2584: USACO 2008 ...