ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Django 框架:表关系的实现(简单版本教务系统)

2021-10-03 21:34:12  阅读:210  来源: 互联网

标签:DateField 映射 教务 数据库 Django models 版本 类型 True


一.常用的字段类型

1. IntegerField(int): 整型,映射到数据库中的int类型。

2. CharField(varchar) : 字符类型,映射到数据库中的varchar类型,通过max_length指定最大长度。

3. TextField(longtext) : 文本类型,映射到数据库中的text类型。

4. BooleanField : 布尔类型,映射到数据库中的tinyint类型,在使用的时候,传递True/False进去。如果要可以为空,则用NullBooleanField。

5. DateField(date) : 日期类型,没有时间。映射到数据库中是date类型,在使用的时候,可以设置DateField.auto_now每次保存对象时,自动设置该字段为当前时间。设置DateField.auto_now_add当对象第一次被创建时自动设置当前时间。

6. DateTimeField(datetime) : 日期时间类型。映射到数据库中的是datetime类型,在使用的时候,传递datetime.datetime()进去。

二.Field的常用参数

1.primary_key: 指定是否为主键。

2.unique: 指定是否唯一。

3.null: 指定是否为空,默认为False。

4.blank: 等于True时form表单验证时可以为空,默认为False。

5.default: 设置默认值。

6.DateField.auto_now: 每次修改都会将当前时间更新进去,只有调用,QuerySet.update方法将不会调用。这个参数只是Date和DateTime以及TimModel.save()方法才会调用e类才有的。

7.DateField.auto_now_add: 第一次添加进去,都会将当前时间设置进去。以后修改,不会修改这个值。

三.表的实现

1.创建一个新的 app

startapp db_test

2.将 app 注册到主文件下

INSTALLED_APPS = [
    'db_test',
]

3.将表写入 app 自带的 models 文件中

from django.db import models
# 学院信息表
class Department(models.Model):
    d_id = models.AutoField(primary_key=True)
    d_name = models.CharField(max_length=30)
# 学生信息表
class Student(models.Model):
    s_id = models.AutoField(primary_key=True)
    s_name = models.CharField(max_length=30)
    # 一对多
    dept = models.ForeignKey('Department', on_delete=models.CASCADE)  # CASCADE 强制删除 SET_NULL 设置为空
# 学生详情表
class Stu_detail(models.Model):
    # 一对一
    stu_id = models.OneToOneField('Student', on_delete=models.CASCADE)   # 默认删除
    age = models.IntegerField()
    gender = models.BooleanField(default=True)
    note = models.TextField()
# 课程信息表
class Course(models.Model):
    c_id = models.AutoField(primary_key=True)
    c_name = models.CharField(max_length=30)
    stu_course = models.ManyToManyField('Student')  # 多对多

标签:DateField,映射,教务,数据库,Django,models,版本,类型,True
来源: https://blog.csdn.net/A15535286714/article/details/120598376

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有