11.字段类型

[TOC]

普通字段

AutoField(自增字段)

一个根据实际ID自动增长的的整型字段,默认不需要使用,因为会自动添加一个主键字段

BinaryField(二进制字段)

只支持bytes赋值

BooleanField(Bool字段)

表单控件是CheckboxInput
如果没设置default 默认值为None

NullBooleanField(Bool字段)

用以代替null=True的BooleanField, 表单控件是 NullBooleanSelect

数字

FloatField(浮点数)

浮点数字段

IntegerField(整数)

32位的整数,范围 -2147483648 到 2147483647(-231~231-1)

BigIntegerField(大整数字段)

64位的整数,范围 -9223372036854775808 到9223372036854775807(-263~263-1)

PositiveIntegerField(正整数字段)

范围依据具体数据库而定 但范围 02147483647(02^31-1)内是所有数据库都ok的

SmallIntegerField(小整数字段)

范围依据具体数据库而定 但范围 -32768 至 32767(-2152^15-1)内是所有数据库都ok的

PositiveSmallIntegerField(小正整数字段)

范围依据具体数据库而定 但范围 02147483647(02^31-1)内是所有数据库都ok的

DecimalField(精确位数的小数)

max_digits指定总位数:decimal_places 指定小数点后的位数

CommaSeparatedIntegerField(逗号分割的整数)

像CharField一样 需要一个max_length

字符串及其变形

CharField(字符串)

必须设置max_length

SlugField(短标题字段)

只能包含字母 数字 下划线 或者连字符 默认加了max_length=50

TextField(文本框字段)

大文本字段,默认表单组件是Textarea,可以使用max_length但只会在渲染Textarea的时候体现出来,不会在model层或数据库层起作用

URLField(网址字段)

有效的url,如果不指定max_length 默认200

EmailField(邮件字段)

使用EmailValidator对类型做检查

GenericIPAddressField(IP地址)

1.7之前可以用IPAddressField表明IPv4字段,但1.7之后把IPv4和IPv6统一划到了这里
此字段类型还提供了一些额外的属性:

  • protocol 指明IP地址类型 一共有三个可选择:both:兼容IPV4和IPV6(默认); ipv4;ipv6(不区分大小写)
  • unpack_ipv4 解析ipv6地址为ipv4(默认false),当 protocol 设置为 both 方可使用
  • 注意 如果设置了blank=True 则同时需要设置null=True

UUID(唯一性)

使用python的UUID库
一个用来存储UUID的字段。使用Python的UUID类。 当使用PostgreSQL数据库时,该字段类型对应的数据库中的数据类型是uuid,使用其他数据库时,数据库对应的是char(32)类型。

使用UUID类型相对于使用具有primary_key参数的AutoField类型是一个更好的解决方案。 数据库不会自动生成UUID,所以推荐使用default参数:

import uuid
from django.db import models

class MyUUIDModel(models.Model):
    id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
    # other fields

注意:这里传递给default是一个可调用的对象(即一个省略了括号的方法),而不是传递一个UUID实例给default

时间类型

DateField(日期)

TimeField(时间)

DateTimeField(日期时间格式)

DurationField(一段时间)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,268评论 19 139
  • 简介 用简单的话来定义tcpdump,就是:dump the traffic on a network,根据使用者...
    保川阅读 5,998评论 1 13
  • IPv6是Internet Protocol Version 6的缩写,其中Internet Protocol译为...
    全能分享阅读 2,307评论 0 3
  • 停用qq空间和朋友圈就是为了不去做无意义的事,我要看有趣而有用的东西,为了两年后自己,加油!我相信我可以做到!晚安!
    sicily涵阅读 170评论 0 0
  • 烈日正午,街边的拉面馆 点了一盘盖浇饭,等…… 忽然就想起最近的一些事和一些人,喝口热汤暖一下。 彼此能在茫茫人海...
    imjax阅读 263评论 0 0