一、功能:

  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. JavaScript中的 JSON 和 JSONP

    JSON 和 JSONP JSONP是一种发送JSON数据的方法,无需担心跨域问题.JSONP不使用该XMLHttpRequest对象.JSONP使用<script>标签代替.由于跨域策略 ...

  2. 读oc52个有效方法的总结

    这本书主要是对于oc语言的代码优化和一些我们不知道的精华.全书分为7章节 1.熟悉oc语言 第一条:了解oc的语言起源 主要是对于oc语言的起源介绍和oc语言的特点进行概括,oc语言主要是使用消息结构 ...

  3. Android探索之百度地图开发

    目录 前言 地图图层介绍 地图覆盖物介绍 地图事件 POI检索 公交线路查询 线路规划 地理编码 @ 前言 之前自己在做一个小项目时涉及到了百度地图的一些内容,当时因为对百度地图的开发流程不是很了解, ...

  4. LeeCode——Combine Two Tables

    Table: Person +-------------+---------+ | Column Name | Type | +-------------+---------+ | PersonId ...

  5. AccessCenter 模块结构

    AccessCenter 模块结构

  6. SpringData系列四 @Query注解及@Modifying注解@Query注解及@Modifying注解

    @Query注解查询适用于所查询的数据无法通过关键字查询得到结果的查询.这种查询可以摆脱像关键字查询那样的约束,将查询直接在相应的接口方法中声明,结构更为清晰,这是Spring Data的特有实现. ...

  7. MVC的View本质和扩展

    一:网站启动流程简介 前面两节我们有介绍管道处理模型,然后下图总结出了mvc启动的整个流程 二:MVC返回的三种结果 从之前的流程已经反编译源码我们晓的,mvc最终都会返回一个结果,其中大概分为以下三 ...

  8. Linux CentOS 防止SSH暴力破解

    一. 问题的发现 昨晚苦逼加班完后,今早上班继续干活时,SSH连接服务器发现异常的提示,仔细看了一下吓一小跳,昨晚9点钟到现在,一夜之间被人尝试连接200+,慌~~~ 1. 速度查一下log [roo ...

  9. 关于VS2015 发布.net mvc 网站失败的问题

    问题:VS生成成功,发布失败,在“正在连接到***文件夹”处就不能继续了.. 项目开发告一段落,准备部署到服务器上进行最后测试,但是始终发布失败  生成成功,发布失败,没有任何提示信息 一开始以为是文 ...

  10. linux 的 expect 自动交互

    https://www.jianshu.com/p/0194cbd70d39 https://www.cnblogs.com/saneri/p/10819348.html  参考 expect是一个自 ...