一.常用的字段类型
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') # 多对多