Django ORM字段参数

先来句鸡汤:当你的才华还撑不起你的野心的时候,你就应该静下心来学习

在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'] # 根据主键从大到小排序

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值