Django中ORM模板常用属性讲解

  • 学习了ORM模板中常用的字段以及使用方法,具体如下:
  • from django.db import models
    
    # Create your models here.
    # 如果要将一个普通的类映射到数据库,必须设置其父类为models.Model
    class Book(models.Model):
        id = models.AutoField(primary_key=True)
        name = models.CharField(max_length=100, null=False)
        author = models.CharField(max_length=100, null=False)
        price = models.FloatField(null=False, default=0)
    
        def __str__(self):
            #  定义返回字符串的格式
            return "<Book:{name},{author},{price}>".format(name=self.name, author=self.author, price=self.price)
    
    
    class Publisher(models.Model):
        name = models.CharField(max_length=100, null=False)
        address = models.CharField(max_length=100, null=False)
    
    
    class Article(models.Model):
        # 如果想自己定义主键,primary_key=True,否则会自动生成id主键
        id = models.BigAutoField(primary_key=True)
        # removed = models.BooleanField(default=True)
        # 如果没有指明null=True,那么默认null=False,
        # 如果想要使用可以为null的BooleanField,那么应该使用NullBooleanField
        removed = models.NullBooleanField()
        # CharField 如果超过254个,不建议使用
        title = models.CharField(max_length=200, null=True)
    
        '''
           naive time: 不知道自己的时间是表示那个时区的时间 
           aware time: 知道自己的时间表示的是那个时区的
           pytz: 库在安装django的时候默认安装,专门用来处理时区的库
           astimezone:将一个时区的时间转化为另一个时区的时间,只能被aware time类型时间使用
           replace: 可以将上述的两种时间表示相互转换(now = now.replace(tzinfo= pytz.timezone(Asia/Shanghai)))
           django.utils.timezone.now(): 会根据’setting.py’中是否设置了‘USE_TZ=True’获取当前时间,如果设置了,那么就会获取到一个‘aware’类型的‘UTC’时间,如果没有,就会获取到一个‘navie’时间。
           django.utils.timezone.localtime(): 会根据’setting.py’中的‘TIME_ZONE'来将一个’aware‘类型的时间转化为‘TIME_ZONE'指定的时区的时间
        '''
    # auto_now_add=True:在第一添加数据的时候会自动获取当前时间 # auto_now: 每次这个对象调用save方法的时候(更改数据的时候会用到save),都会将当前的时间更新,在更新时间字段用得到 create_time = models.DateTimeField(auto_now_add=True) class Person(models.Model): # EmailField在数据库层面不会限制你存储的格式 email = models.EmailField() context = models.TextField()

      建立迁移文件命令:python manage.py makemigrations    迁移文件:python manage.py migrate

  • 常用字段: 在 Django 中,定义了一些 Field 来与数据库表中的字段类型来进行映射。以下将介绍那些常用 的字段类型。
  • AutoField: 映射到数据库中是 int 类型,可以有自动增长的特性。一般不需要使用这个类型,如果不指定主 键,那么模型会自动的生成一个叫做 id 的自动增长的主键。如果你想指定一个其他名字的并且具 有自动增长的主键,使用 AutoField 也是可以的。
  • BigAutoField: 64位的整形,类似于 AutoField ,只不过是产生的数据的范围是从 1-9223372036854775807 。
  • BooleanField: 在模型层面接收的是 True/False 。在数据库层面是 tinyint 类型。如果没有指定默认值,默认值 是 None 。
  • CharField: 在数据库层面是 varchar 类型。在 Python 层面就是普通的字符串。这个类型在使用的时候必须 要指定最大的长度,也即必须要传递 max_length 这个关键字参数进去。
  • DateField: 日期类型。在 Python 中是 datetime.date 类型,可以记录年月日。在映射到数据库中也 是 date 类型。使用这个 Field 可以传递以下几个参数: 1. auto_now :在每次这个数据保存的时候,都使用当前的时间。比如作为一个记录修改日期的 字段,可以将这个属性设置为 True 。 2. auto_now_add :在每次数据第一次被添加进去的时候,都使用当前的时间。比如作为一个记 录第一次入库的字段,可以将这个属性设置为 True 。
  • DateTimeField:日期时间类型,类似于 DateField 。不仅仅可以存储日期,还可以存储时间。映射到数据库中 是 datetime 类型。这个 Field 也可以使用 auto_now 和 auto_now_add 两个属性。 TimeField: 时间类型。在数据库中是 time 类型。在 Python 中是 datetime.time 类型。
  • EmailField: 类似于 CharField 。在数据库底层也是一个 varchar 类型。最大长度是254个字符。
  • FloatField: 浮点类型。映射到数据库中是 float 类型。
  • IntegerField: 整形。值的区间是 -2147483648——2147483647 。
  • BigIntegerField: 大整形。值的区间是 -9223372036854775808——9223372036854775807 。
  • PositiveIntegerField: 正整形。值的区间是 0——2147483647 。 SmallIntegerField: 小整形。值的区间是 -32768——32767 。
  • PositiveSmallIntegerField:正小整形。值的区间是 0——32767 。
  • TextField: 大量的文本类型。映射到数据库中是longtext类型。
  • UUIDField: 只能存储 uuid 格式的字符串。 uuid 是一个32位的全球唯一的字符串,一般用来作为主键。
  • URLField: 类似于 CharField ,只不过只能用来存储 url 格式的字符串。并且默认的 max_length 是200。
  •  
  •  
  •  
  •  以上。
posted @ 2018-12-06 17:06  大长胡子  阅读(541)  评论(0编辑  收藏  举报