Django 字段类型
字段类型 |
含义 |
数据库表示 |
AutoField |
int 自增列,必须填入参数 |
integer AUTO_INCREMENT |
BigAutoField |
bigint 自增列,必须填入参数 |
bigint AUTO_INCREMENT |
SmallIntegerField |
小整数 -32768 ~ 32767 |
smallint |
PositiveSmallIntegerField |
正小整数 0 ~ 32767 |
smallint UNSIGNED |
IntegerField |
整数列(有符号的) -2147483648 ~ 2147483647 |
integer |
BigIntegerField |
长整型(有符号的) -9223372036854775808 ~ 9223372036854775807 |
bigint |
PositiveIntegerField |
正整数 0 ~ 2147483647 |
integer UNSIGNED |
BooleanField |
布尔值类型 |
bool |
NullBooleanField |
可以为空的布尔值 |
bool |
CharField |
字符类型,必须提供 max_length 参数, max_length 表示字符长度 |
varchar |
TextField |
文本类型 |
longtext |
EmailField |
字符串类型,Django Admin 以及 ModelForm 中提供验证机制 |
|
IPAddressField |
字符串类型,Django Admin 以及 ModelForm 中提供验证 IPV4 机制 |
|
GenericIPAddressField |
字符串类型,Django Admin 以及 ModelForm 中提供验证 Ipv4 和 Ipv6 |
|
URLField |
字符串类型,Django Admin 以 及 ModelForm 中提供验证 URL |
|
|
|
|
SlugField |
字符串类型,Django Admin 以及 ModelForm 中提供验证支持字母、数字、下划线、连接符(减号 |
|
CommaSeparatedIntegerFiel d |
字符串类型,格式必须为逗号分割的数字 |
|
UUIDField |
字符串类型,Django Admin 以及 ModelForm 中提供对 UUID 格式的验证 |
|
FilePathField |
字符串,Django Admin 以及 ModelForm 中提供读取文件夹下文件的功能 |
|
FileField |
字符串,路径保存在数据库,文件上传到指定目录 参数: upload_to = "" 上传文件 的保存路径 torage = None 存储组件, 默 认 django.core.files.storage.F ileSystemStorage |
|
ImageField
|
字符串,路径保存在数据库,文件上传到指定目录 参数: upload_to = "" 上传文件的保存路径 storage = None 存储组件,默认 django.core.files.storage.F ileSystemStorage width_field=None,上传图片的高度保存的数据库字段名(字符串) height_field=None 上传图片的宽度保存的数据库字段名(字符串)
|
|
DateTimeField |
日期+时间格式 YYYY-MM-DD |
|
|
HH:MM[:ss[.uuuuuu]][TZ] |
|
DateField |
日期格式 YYYY-MM-DD |
|
TimeField |
时间格式HH:MM[:ss[.uuuuuu]] |
|
DurationField |
长整数,时间间隔,数据库中按照 bigint 存储,ORM 中获取的值为 datetime.timedelta 类型 |
|
FloatField |
浮点型 |
|
DecimalField |
10 进制小数 - 参数: max_digits,小数总长度 decimal_places,小数位长度 |
|
BinaryField |
二进制类型 |
|
字段参数含义:
default 数据库中字段的默认值
primary_key 数据库中字段是否为主键
db_index 数据库中字段是否可以建立索引
unique 数据库中字段是否可以建立唯一索引
unique_for_date 数据库中字段【日期】部分是否可以建立唯一索引
unique_for_month 数据库中字段【月】部分是否可以建立唯一索引
unique_for_year 数据库中字段【年】部分是否可以建立唯一索引
verbose_name Admin 中显示的字段名称
blank Admin 中是否允许用户输入为空
editable Admin 中是否可以编辑
help_text Admin 中该字段的提示信息
choices Admin 中显示选择框的内容,用不变动的数据放在内存中从而避免跨表操作
如:gf = models.IntegerField(choices=[(0, '何穗'),(1, '大表姐'),],default=1)
error_messages 自定义错误信息(字典类型),从而定制想要显示的错误信息; 字典健:null, blank, invalid, invalid_choice, unique, and unique_for_date
如:{'null': "不能为空.", 'invalid': '格式错误'}
validators 自定义错误验证(列表类型),从而定制想要的验证规则from django.core.validators import RegexValidator from django.core.validators import EmailValidator,URLValidator,DecimalValidator, MaxLengthValidator,MinLengthValidator,MaxValueValidator,MinValueValidator
如: test = models.CharField( max_length=32, error_messages={ 'c1': '优先错信息 1', 'c2': '优先错信息 2', 'c3': '优先错信息 3', }, validators=[ RegexValidator(regex='root_\d+', message='错误了', code='c1'), RegexValidator(regex='root_112233\d+',message='又错误了', code='c2'), EmailValidator(message='又错误了',code='c3'), ] )
unique_for_date #只对时间做索引
unique_for_month #只对月分做索引unique_for_year
auto_now #更新时,自动更新为当前时间auto_now_add #创建时,自动生成