11.字段类型

作者: qy1994 | 来源:发表于2017-10-04 23:19 被阅读0次

[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(一段时间)

相关文章

  • 11.字段类型

    [TOC] 普通字段 AutoField(自增字段) 一个根据实际ID自动增长的的整型字段,默认不需要使用,因为会...

  • Django 模型层 orm 单表操作

    一、ORM用法 1.字段类型: 属性名 = models.字段类型(定义属性时需要指定字段类型, 通过字段类型的参...

  • sqlite常用语句总结

    //创建表格 create table 表名(字段名1 字段类型1,字段名2,字段类型2,字段名3 字段类型3,....

  • java基础-day32-数据库3.0

    10.6 外键约束 10.7 级联操作 11. 数据表修改 alter 11.1 添加字段 11.2 修改字段 1...

  • 数据库表的基本的操作DDL

    新建一张表 create table 表名称( 字段1 字段的类型, 字段2 字段的类型, ...

  • 字段类型

    学习自: BoogeyChen数字数据类型: INT:正常大小的整数,可以带符号。有符号的,范围是-2147483...

  • greendao3.2 数据库增加字段

    greenDAO 3.2 生成的字段添加了非空约束。 字段类型为基本类型默认会添加非空约束,字段类型设置为对象类型...

  • SQLite中常用的SQL语句

    创建表:creat table 表名 (字段名 字段数据类型 是否为主键, 字段名 字段数据类型, 字段名 字段数...

  • MySQL timestamp 类型比较的测试

    TIMESTAMP 类型字段与 CHAR 比较: TIMESTAMP 类型字段与 TIMESTAMP 比较: 实验...

  • 2018-11-01

    关于mysql数据库字段类型,以及javabean字段类型 数据库中类型 int和integer类型相同,没有区别...

网友评论

    本文标题:11.字段类型

    本文链接:https://www.haomeiwen.com/subject/iwchyxtx.html