上一篇咱们已经建立好了一个Xadmin的基础项目,如今咱们将在此基础上构建一个一样很基础的学生信息管理系统。python
1、建立模型数据库
模型是表示咱们的数据库表或集合类,而且其中所述类的每一个属性是表或集合的字段,在 app/models.py 中定义。django
一、首先,导入models模块app
from django.db import models
接下来建立个学生信息类,其中包含学生姓名、性别、年龄、入学时间、家庭住址等信息:学习
class Students(models.Model): name = models.CharField(verbose_name='学生姓名', max_length=50) sex = models.CharField(verbose_name='性别', max_length=50) age = models.IntegerField(verbose_name='年龄') address = models.CharField(verbose_name='家庭住址', max_length=250, blank=True) enter_date = models.DateField(verbose_name='入学时间') remarks = models.TextField(verbose_name='备注', blank=True)
在终端内执行这两个数据库修改同步的命令3d
python3 manage.py makemigrations python3 manage.py migrate
如今看看数据库,已经有了这张咱们已经建立好的表及相关字段:blog
二、建立好数据表以后,接下来要将数据模型展现到页面rem
首先,将app/admin.py文件重命名为adminx.py,并导入模块同步
import xadmin from .models import *
在前面咱们已经建立好了一张包含学生姓名、性别、年龄、入学时间、家庭住址等信息的数据表,如今若是想要让其中的学生姓名、性别、年龄、入学时间显示在界面上,那就要建立一个类,其中的 list_display 属性包含须要展现在页面的相关字段:it
class StudentsAdmin(object): list_display = ('name', 'sex', 'age', 'address',)
最后,对其进行注册:
xadmin.site.register(Students, StudentsAdmin)
来看看页面长得是这样子的:
三、本地化语言显示
是否发现左侧栏目显示的仍是Students,咦,不对,怎么会是Students呢?缘由就在于,英文单词有单数和复数之分,左侧这一栏默认是以类名最后加's'做为复数显示的。那咱们想要把它改成中文,要怎么作呢?接下来,就来操做:
在models.py的Students类下添加类属性:
class Students(models.Model): name = models.CharField(verbose_name='学生姓名', max_length=50) sex = models.CharField(verbose_name='性别', max_length=50) age = models.IntegerField(verbose_name='年龄') address = models.CharField(verbose_name='家庭住址', max_length=250, blank=True) enter_date = models.DateField(verbose_name='入学时间') remarks = models.TextField(verbose_name='备注', blank=True) class Meta: verbose_name = '学生信息' verbose_name_plural = '学生信息' def __str__(self): return self.name
四、下拉选项
到这里,咱们会发如今添加学生信息的时候,其中有一个性别字段,每次都要手动输入“男”/“女”,要是弄成下拉选择框,那就省事了,有办法:
在Students类里添加
SEX = ( ('male', '男'), ('female', '女') )
而后修改sex字段
修改前:
sex = models.CharField(verbose_name='性别', max_length=50)
修改后:
sex = models.CharField(choices=SEX, verbose_name='性别', max_length=50)
同时,记得对模型的修改操做,凡有涉及到数据库的,都要进行同步操做,运行命令:
python3 manage.py makemigrations python3 manage.py migrate
*有了学生信息以后,还须要添加个学生所属的班级信息。一样的,在models.py里添加一个班级类:
class Class(models.Model): class_name = models.CharField(verbose_name='班级', max_length=100) class Meta: verbose_name = '班级' verbose_name_plural = '班级' def __str__(self): return self.class_name
*注意,这两个类必须写在Students类的上面,不然没法被Students类识别
仍是同样,修改adminx.py,对这两个类进行注册和页面自定义展现操做:
class ClassAdmin(object): list_display = ('class_name',) xadmin.site.register(Class, ClassAdmin)
这里咱们先把班级信息给填写完整,以后须要对Students类关联这这两张表
*外键的操做:
在Students类里添加:
grade_name = models.ForeignKey(Grade, verbose_name='所在年级', on_delete=models.CASCADE, blank=True, null=True) class_name = models.ForeignKey(Class, verbose_name='所在班级', on_delete=models.CASCADE, blank=True, null=True)
这里的ForeignKey表明使用外键,用到的是咱们上面建立好的年级和班级这两张表的信息,blank=True和null=True表明能够为空,非必填字段。
使用数据库同步命令:
python3 manage.py makemigrations python3 manage.py migrate
学生须要有他要学习的课程,如今咱们就来建立课程的数据表,一样的须要写在学生表前面:
models.py文件内添加:
class Subjects(models.Model): name = models.CharField(verbose_name='课程名称', max_length=50, blank=True) score = models.IntegerField(verbose_name='学分', blank=True) class Meta: verbose_name = '课程信息' verbose_name_plural = '课程信息' def __str__(self): return self.name
adminx.py文件内添加:
class SubjectsAdmin(object): list_display = ('name', 'score',) xadmin.site.register(Subjects, SubjectsAdmin)
*多对多关系:
一个学生须要选修的课程通常很多于1门,那就须要用到多对多关系:
修改Student类,添加一个选修课程字段:
subjects = models.ManyToManyField(Subjects, verbose_name='选修课程')
同步一下数据库信息,方法前面提到,这里再也不赘述。
咱们看到的选修课程的选项彷佛有点丑,并且一旦选择了就没法取消。这就须要对adminx.py进行修改,自定义显示风格:
在StudentsAdmin内中添加一个内联复选框:
style_fields = {'subjects': 'checkbox-inline', }
这里要注意一个地方,刚才咱们在Students类中建立subjects字段时,没有设置其为非必填字段,这里就会致使必须勾选了全部选项以后才让保存。因此,正确的作法应该是要修改Students中的subjects字段,加入blank=True
subjects = models.ManyToManyField(Subjects, verbose_name='选修课程', blank=True)
(xadmin2.0貌似有个bug,这里原本应该显示横排的复选框,可是却显示成了竖着的,在Django1.x+xadmin0.6的组合里使用显示是正常的)
有了学生以后,咱们再来建立教师信息表:
models.py文件中加入:
class Teachers(models.Model): name = models.CharField(verbose_name='教师姓名', max_length=50) class Meta: verbose_name = '教师信息' verbose_name_plural = '教师信息' def __str__(self): return self.name
adminx.py文件中加入:
class TeachersAdmin(object): list_display = ('name',) xadmin.site.register(Teachers, TeachersAdmin)
不要忘记了同步数据库。
*一对一关系:
假设学校规定,一个教师只能担任一个班级的班主任,那就须要用到一对一关系:
修改models.py的Class表,添加headmaster字段:
headmaster = models.OneToOneField(Teachers, verbose_name='班主任', on_delete=models.CASCADE, blank=True, null=True)
这里的OneToOneField就是一对一关系了,执行数据库同步命令。
如今在页面上的班级信息里选择班主任,一个班主任在被一个班级选定以后,其余班级是没法再选择的: