先来句鸡汤:当你的才华还撑不起你的野心的时候,你就应该静下心来学习
在Djangon中,
· 一个类对应数据库中一个表
· 一个类属性对应数据库表中的一个字段
快速入门:
创建一个数据模型
# 一个类就代表了一个数据表
class User(models.Model):
# 数据表的表名
class Meta():
db_table = 'user'
# 每个字段是都Filed类的实例
username = models.CharField(max_length=30,default='小西') # 这是一个类变量,表示数据库的一个字段
userpassword = models.CharField(max_length=30)
def __repr__(self):
return '用户名:{},密码:{}'.format(self.username,self.userpassword)
__str__ = __repr__
Django ORM常用字段 和参数
1、AutoField
自增列,通常自定义主键时,需要的字段,字段必须填入参数 primary_key=True才能被认为是主键。当你没有自定义主键时,则自动会创建一个列名为id的自动增长的主键。
2、IntegerField
一个整数类型,范围在-2147483648——2147483647
3、CharField
字符串类型,必须提供max_length字符串长度这个 参数,如果超过254个字符,则不建议使用它,使用TextField
时间字段
4、DataField
日期字段,日期格式 为 year-month-day,相当于 Python 中的datetime.date( ) 实例,这个字段可传递auto_now / auto_now_add
5、DateTimeField
日期时间字段,不仅仅可以存日期,还可以时间。存格式year-month-day hour:minute:second,相当于Ptyhon中的datetime.datetime( ) ,这个Field也可以使用auto_now / auto_now_add 两个属性。
6、TimeField
一个时间格式
8、TextField
一个文本类型,可以存储任意长度的字符( longtext 类型)可存储任意长度的字符串。
9、BooleanField
一个布尔类型,在模型层面是True和False,但是在数据库层面是1和0,它的类型是tinyint(微整形)
class Book(models.Model):
remove = models.Boolean(default=True) # 这个字段表示一个状态,前端把书籍删除,不是真正把数据库中的书籍删了,而只是前端没有了而已,数据库还是有的,所以用True或False来表示一个是否删除了的状态
10、FloatField
一个浮点型类型
11、EmailField
正则表达式邮箱,在数据库层面并不会加一层验证,也就是说存什么都可以!在数据库底层是一个varchar类型。最大长度是254个字符。
参数
字段参数:
null=True 用于表示某个字段可以为空。
unique=True 如果设置unique=True,则该字段在此表中必须是唯一的。
db_index = True 如果设置db_index=True,则该字段设置索引。
default='xxx' 设置默认值
blank= True 标识这个字段在表单验证的时候是否为空
db_column 可改变模型中类属性的名字
name = models.CharField(max_length=50,db_column='author_name') # 保存到数据库中的名字是author_name
unique 指定该字段是唯一的
DateField和DateTimeField
auto_now_add=True 如果设置为True,只有第一次保存数据的时候,他还以自动获取当前的时间(文章创建的时间)。
auto_now=True 每次对象调用save方法的时候,都会将当前的时间更新(文章更新的时间)。
补充:
verbose_name='标题 ' 一个字段描述性的属性。
关系字段:(重点)
ForeignKey 外键
个人理解:外键就是表与表之间建立关系的桥梁
ForeignKey( '引用的模型',on_delete ) 参数一:引用的模型;参数二:所引用的表被删除了,这个字段如何处理。
<1> 2个类在同一文件中
# 父类
class Blog(models.Model):
uid = models.AutoField(primary_key=True)
username = models.CharField(max_length=30,default='小西')
userpassword = models.CharField(max_length=30)
create_time = models.DateTimeField(auto_now_add=True,null=True)
def __repr__(self):
return '{}{}'.format(self.username,self.userpassword)
__str__ = __repr__
# 子类,之所以叫它子类,外键是Blog,因为它引用了上边父类
class Artical(models.Model):
artical = models.TextField(default='this is a artical.')
# default为1,默认与Blog类中的uid=1的对象进行关联
atuthor = models.ForeignKey('Blog',to_field='uid',default=1,on_delete=models.CASCADE)
<2> 引用的外键在另一个应用中:
atuthor = models.ForeignKey('应用文件夹名.模型名就是类名',to_field='uid',default=1,on_delete=models.CASCADE)
<3> 自身的引用,外键就是自身(通常这个操作应用:多级评论等等)
第一个参数:self 或者自己模型的名字
class Conmment(models.Model):
uid = models.AutoField(primary_key=True)
title = models.CharField(max_length=50)
con = models.ForeignKey('self',on_delete=models.CASCADE,default=1) # 外键默认是自身主键为1的对象
参数二:
ForeignKey()参数二可以分为:
on_delete = models.CASCADE : 等级操作,也就是说它关联的对象外键删除了,自身也会被删除。
on_delete = models.PROTECT : 受保护的,只要自身引用了外键那条数据,就不能删除外键的那条数据。
on_delete = models.SET_NULL :设置为空,如果引用的外键被删除了,那个自身这条数据会被设置为空,但是前提,这个字段要指定为null=True才行,可以为空才行!
模型中Meta类
在模型级别的配置中,可以定义一个类Meta,我们可以这个类中添加一些类属性,来控制模型。
db_table = 'xxx'
为模型添加名字,默认映射到数据库的名字是 应用名_模型类的名字
class User(models.Model):
user = models.CharField(max_length=10)
class Meta():
db_table = 'user' # 映射到数据库的名字为user
ordering
按照某种排序方式进行排序。
class User(models.Model):
user = models.CharField(max_length=10,default='lxc')
class Meta():
db_table='user'
ordering=['id'] # 根据主键从小到大排序
ordering=['-id'] # 根据主键从大到小排序