ORM版,学生管理系统02
学生管理系统
urls.py
url(r'^student_list/$',views.student_list,name="student_list"),
url(r'^delete_student/(?P<sid>\d+)/$',views.delete_student,name="delete_student"),
url(r'^add_student/',views.add_student,name="add_student"),
url(r'^edit_student/(?P<sid>\d+)/$',views.edit_student,name="edit_student"),
urls
视图部分
# 展示学生信息
def student_list(request):
# 查找到所有学生
student_list = models.Student.objects.all()
return render(request,"student_list.html",{"student_list":student_list}) # 删除学生信息
def delete_student(request,sid):
# 从数据库里面取id值为sid的学生对象
models.Student.objects.filter(id=sid).delete()
# 删除成功,跳转到student_list
return redirect(reverse("student_list")) # 添加学生信息
def add_student(request):
if request.method == "POST":
sname = request.POST.get("sname")
cid = request.POST.get("cid") # 取数据库创建
models.Student.objects.filter().create(sname=sname,cid_id = cid)
return redirect(reverse("student_list"))
class_list = models.Class.objects.all()
return render(request,"add_student.html",{"class_list":class_list}) # 编辑学生信息
def edit_student(request,sid):
student_obj = models.Student.objects.get(id=sid) if request.method == "POST":
sname = request.POST.get("sname")
cid = request.POST.get("cid")
# 更新student_obj
student_obj.sname = sname
student_obj.cid_id = cid
student_obj.save()
return redirect(reverse("student_list")) class_list = models.Class.objects.all()
return render(request,"edit_student.html",{"class_list":class_list,"student":student_obj})
前端部分
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>添加学生信息</title>
</head>
<body>
<h1>添加学生信息</h1>
<form action="{% url 'add_student' %}" method="post">
{% csrf_token %} {# 跨站请求伪造保护 #}
<label for="i1">学生姓名:</label>
<input id="i1" type="text" value="" name="sname">
<label for="i2">所在班级:</label>
<select name="cid" id="i2">
{% for class in class_list %}
<option value="{{ class.id }}">{{ class.cname }}</option>
{% endfor %}
</select> <button type="submit">提交</button>
<button><a href="{% url 'student_list' %}">取消</a></button> </form>
</body>
</html>
add_student
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>学生信息表</title>
</head>
<body>
<button><a href="{% url 'add_student' %}/">
添加
</a></button> <table border="1px">
<thead>
<tr>
<th>#</th>
<th>学生ID</th>
<th>学生姓名</th>
<th>所在班级</th>
<th>操作</th> </tr>
</thead>
<tbody>
{% for student in student_list %} <tr>
<td>{{ forloop.counter }}</td>
<td>{{ student.id }}</td>
<td>{{ student.sname }}</td>
<td>{{ student.cid.cname }}</td>
<td>
<button><a href="{% url 'edit_student' student.id %}">
编辑
</a></button>
<button><a href="{% url 'delete_student' student.id %}">
删除
</a></button>
</td>
</tr> {% endfor %}
</tbody>
</table> </body>
</html>
学生页面
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>编辑学生信息页面</title>
</head>
<body>
<h1>编辑学生信息</h1>
<form action="{% url 'edit_student' student.id %}" method="post">
{% csrf_token %} {# 跨站请求伪造保护 #}
<label for="i1"></label>
<input id="i1" type="text" name="id" value="{{ student.id }}" style="display: none">
<label for="i2">学生姓名</label>
<input id="i2" type="text" name="sname" value="{{ student.sname }}"> <label for="i3">所在班级</label>
<select name="cid" id="i3">
{% for class in class_list %}
{% if student.cid.id == class.id %}
<option selected value="{{ class.id }}">{{ class.cname }}</option>
{% else %}
<option value="{{ class.id }}">{{ class.cname }}</option>
{% endif %} {% endfor %} </select>
<button type="submit">提交</button>
<a href="{% url 'student_list' %}"><button type="submit">取消</button></a>
</form> </body>
</html>
编辑页面
为什么说cid为一个对象
表之间的关系
对应关系:
类 --> 表
类的属性 --> 字段
实例对象 --> 一条数据(数据行)
基于对象的跨表查询
一对多查询(班级表和学生表)
正向查询
(由学生表查询班级表) 按字段
查询学生的班级信息
>>> student_obj = models.Student.objects.first()
>>> student_obj.cid # /通过model类中的属性查找到对应的外键数据对象
---> <Class: linux4期> >>> student_obj.cid.cname
---> 'linux4期' >>> student_obj.cid_id # 获取实际外键的值
---> 2
反向查询
(有班级表查询学生表) 表名_set
默认是表名_set.all()
如果在外键的字段中加了related_name属性,则按照该属性的来反向查找
>>> class_obj = models.Class.objects.first() # 获取第一个班级对象
>>> class_obj.student_set.all() # 通过表名_set反向查询出所有的学生 models.Class.objects.first().student_set.all() # 通过表名_set反向查询出所有的学生 --> <QuerySet [<Student: lishi>, <Student: dandan>, <Student: lili>]>
如果设置了related_name="students",反向查询时可直接使用students进行反向查询。
>>> models.Class.objects.first().students.all()
--><QuerySet [<Student: lishi>, <Student: dandan>, <Student: lili>]>
一对一查询
表结构设计
class Student(models.Model):
id = models.AutoField(primary_key=True)
sname = models.CharField(max_length=20)
cid = models.ForeignKey(to="Class",to_field="id",related_name="students",null=True)
# 表里面:student_obj.cid_id=Class对象.id ; student_obj.cid=Class对象
# related_name="students" 这个参数好处,表明我在class表的时候能够通过“students” 来找student的类
detail = models.OneToOneField("StudentDetail",null=True) def __str__(self):
return self.sname
# class StudentDetail(models.Model):
height = models.PositiveSmallIntegerField()
email = models.EmailField()
memo = models.CharField(max_length=128,null=True)
正向查询
(由学生信息表查询学生详情表) 按字段
>>> student_obj = models.Student.objects.first()
>>> student_obj.detail.email
--- '11@55.com'
反向查询
(由学生详情表反向查询学生信息表) 按表名
>>> a = models.StudentDetail.objects.get(id=1)
>>> a.student.sname
---- 'lishi'
总结
所有的反向的查询的表名均为小写,且需要提醒的是在一对一的反向查询中表名不需要跟set,因为它只有一个对象,通过“.表名”得到的是一个models对象,可以直接查询需要的字段。
关于student.cid.cname

ORM版,学生管理系统02的更多相关文章
- ORM版学员管理系统
ORM版学员管理系统 班级表 表结构 class Class(models.Model): id = models.AutoField(primary_key=True) # 主键 cname = m ...
- ORM版学员管理系统1
ORM版学员管理系统 班级表 表结构 class Class(models.Model): id = models.AutoField(primary_key=True) # 主键 cname = m ...
- python简易版学生管理系统
#coding=utf- def showInfo(): print("**************") print(" 学生管理系统") print(&quo ...
- ORM版学员管理系统 2
学生信息管理 展示学生信息 URL部分 url(r'^student_list/', app01_views.student_list, name="student_list"), ...
- ORM版学员管理系统2
学生信息管理 展示学生信息 URL部分 url(r'^student_list/', app01_views.student_list, name="student_list"), ...
- ORM版学员管理系统 3
老师信息管理 思考 三种方式创建多对多外键方式及其优缺点. 通过外键创建 class Class(models.Model): id = models.AutoField(primary_key=Tr ...
- ORM版学员管理系统3
老师信息管理 思考 三种方式创建多对多外键方式及其优缺点. 通过外键创建 class Class(models.Model): id = models.AutoField(primary_key=Tr ...
- Django之ORM版学员管理系统
班级表 表结构 class Class(models.Model): id = models.AutoField(primary_key=True) # 主键 cname = models.CharF ...
- Java 简化版学生管理系统(IO版)
Student management system 学生管理系统IO版 详细知识点可参考一下几篇文章 常用API Java 之ArrayList集合及应用 Java 之IO流及应用 Compreh ...
随机推荐
- NAT配置与管理
为解决IPv4地址日益枯竭,出现NAT(Network Address Translation,网络地址转换)技术.NAT可以将来自一个网络的IP数据报报头中的IP地址(可以是源IP地址或目的IP地址 ...
- 优秀 H5 案例收集 vol.3(不定期更新)
上期浏览:Vol.1 Vol.2 爱的不同定义,五笔连成爱http://news.163.com/special/fdh5_valentines/ 世界华语悬疑文学大赛—下一位悬疑大师,就是你!h ...
- HCNP学习笔记之ICMP协议与ping原理以及用Python实现ping
一.ICMP协议分析 ICMP:Internet控制报文协议.由于IP协议并不是一个可靠的协议,它不保证数据被成功送达,那么,如何才能保证数据的可靠送达呢? 这里就需要使用到一个重要的协议模块ICMP ...
- Mysql 忘记密码处理配置
Mysql忘记密码处理 1.设置mysql密码 mysqladmin -uroot password ‘密码’ 2.主配置文件下取消密码授权 vim /etc/my.cnf 注:加入skip-gran ...
- ASP.NET MVC Bootstrap模板选中菜单高亮显示当前项方法
当我们处理后台显示当前页面,当前页菜单项高亮,我们可以使用js方法,也可用程序实现,使用Bootstrap模板处理高亮并展开方法之一 1.在项目中导入 <script src="/as ...
- shell 中的 eval 及 crontab 命令
eval eval会对后面的命令进行两遍扫描,如果第一遍扫描后,命令是个普通命令,则执行此命令:如果命令中含有变量的间接引用,则保证间接引用的语义.也就是说,eval命令将会首先扫描命令行进行所有的置 ...
- UDP协议----简单的CS模型实现
UDP简单介绍 传输层主要应用的协议模型有两种,一种是TCP协议,另外一种则是UDP协议.TCP协议在网络通信中占主导地位,绝大多数的网络通信借助TCP协议完成数据传输.但UDP也是网络通信中不可或缺 ...
- Windows Server 2008 R2服务器遗忘管理员密码解决方案
A goal is a dream with a deadline. Much effort, much prosperity. 在日常的工作中,对于一个网络管理员来讲最悲哀的事情莫过于在没有备用 ...
- 举例讲解Linux中tcpdump工具的应用
先来看一个比较基本的用法: tcpdump -i eth0 其中,eth0为参数值,表示需要抓包的网口,这是个必需参数哦. tcpdump的具体参数及意义: -i:指定tcpdump监听的网络接口 - ...
- 华丽的使用sublime写lua~ sublime lua相关必装插件推荐~~
缘起 lua脚本语言虽好,代码写得飞快,可是写错了调试起来却很困难,lua使用者经常容易犯得一个错误是--写错变量名了,if end 嵌套太多没匹配~,多打了一个逗号, --假设定义了一个变量 loc ...