Django中的常用字段类型与参数
Django中的常用字段类型
1. 数值型
以下都是数值相关的,比如AutoField,它在MySQL中的类型为int(11),而BooleanField在MySQL中对应的类型是tinyint(1)
AutoField int(11)
自增主键,Django Model默认提供,可以被重写。它的完整定义是id=models.AutoField(primary_key=True)
BooleanField tinyint(1)
布尔类型字段,一般用于记录状态标记
DecimalField decimal
开发对数据精度要求较高的业务时考虑使用,比如做支付相关,金融相关。定义时,需要指定到多少位,比如cash = models.DecimalField(max_digits=8, decimal_placee=2, default=0, verbose_name="消费金额")就是定义长度为8位、精度为2的数字。比方说,你想保存666.66这样的数字那么你的max_digits就需要为5,decimal_places需要为2
值得注意的是,在Python中也要使用Decimal类型来转换数据(from decimal import Decimal)
IntegerField int(11)
它同AutoField一样,唯一的差别就是不自增
PositiveIntegerField
与IntegerField一样,但只包含正整数
SmallIntegerField smallint
小整数时一般会用到
2. 字符型
以下这些字段都是用来存储字符数据的,对应在MySQL中有两种类型:longtext和varchar
除了TextField是longtext类型外,其他均属于varchar类型。
CharField varchar
基础的varchar类型
URLField
继承自CharField,但是实现了对URL的特殊处理
UUIDField char(32)
除了在PostgreSQL中使用的是uuid类型外,在其他数据库中均是固定长度char(32),用来存放生成的唯一id
EmailField
同URLField一样,他继承自CharField,多了对E-mail的特殊处理
FileField
同URLField一样,它继承自CharField,多了对文件的特殊处理。当你定义一个字段为FileField时,在admin部分展示时会自动生成一个可上传文件的按钮。
TextField longtext
一般用来存放大量文本内容,比如新闻正文、博客正文
ImageField
继承自FileField,用来处理图片相关的数据,在展示上会有所不同
3. 日期类型
以下都为日期类型,分别对应MySQL的date、datetime和time
DateField
DateTimeField
TimeField
4. 关系类型
这是关系型数据库中比较重要的字段类型,用来关联两个表,具体如下:
ForeignKey
OneToOneField
ManyToManyField
Django中的常用字段参数
null
可以同blank对比考虑,其中null用于设定在数据库层面是否允许为空
blank
针对业务层面,该值是否允许为空。
choices
配置字段的choices后,在admin页面上就可以看到对应的选项展示。
db column
默认情况下,我们定义的Field就是对应数据库中的字段名称,通过这个参数可以指定Model中的某个字段对应数据库中的哪个字段。
db_ index
索引配置。对于业务上需要经常作为查询条件的字段,应该配置此项。
default
默认值配置。
editable
是否可编辑,默认是True。 如果不想将这个字段展示到页面上,可以配置为False。
error_ messages
用来自定义字段值校验失败时的异常提示,它是字典格式。key 的可选项为null、blank、invalid、invalid_choice、unique 和unique_for_date
help_text
字段提示语,配置这一项后,在页面对应字段的下方会展示此配置。
primary_key
主键,一个Model只允许设置一个字段为 primary_key。
unique
唯一约束,当需要配置唯一值时,设置unique=True, 设置此项后,不需要设置db_ index。
unique_ for_ date
针对date (日期)的联合约束,比如我们需要一 天只能有一篇名为《Django》的文章,那么可以在定义title字段时配置参数: unique _for_date="created time"。
需要注意的是,这并不是数据库层面的约束。
unique_ for_ month
针对月份的联合约束
unique_ for_ year
针对年份的联合约束。
verbose_ name
字段对应的展示文案。
validators
自定义校验逻辑,同form类似
Django中的常用字段类型与参数的更多相关文章
- Django中ORM常用字段类型及参数
常用字段: <1> CharField 字符串字段, 用于较短的字符串. CharField 要求必须有一个参数 maxlength, 用于从数据库层和Django校验层限制该字段所允许的 ...
- Django中ORM常用字段及字段参数
Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据 ...
- Django models 的常用字段类型和字段参数
<1> CharField #字符串字段, 用于较短的字符串. #CharField 要求必须有一个参数 maxlength, 用于从数据库层和Django校验层限制该字段所允许的最大字符 ...
- 潭州课堂25班:Ph201805201 django框架 第七课 常用 字段类型及参数,关系表的实现,表关系对象add,create的方法 (课堂笔记)
写个类,创建表格 执行命令生成文件 提交,在数据库中创建 进入数据库查看 对数据进行修改操作 只有用到 save() 才能触发 updaer_time 的更改, 下边 update 方法不会修改 up ...
- django ORM 增删改查 模糊查询 字段类型 及参数等
ORM 相关 #sql中的表 #创建表: CREATE TABLE employee( id INT PRIMARY KEY auto_increment , name VARCHAR (), gen ...
- Django创建数据库常用字段及参数
Django创建数据库常用字段及参数 常用字段 1.models.AutoField 自增列= int(11) 如果没有的话,默认会生成一个名称为 id 的列,如果要显示的自定义一个自增列,必须将给列 ...
- Django模型类之models字段类型和参数以及元数据meta
models之字段类型和参数 示例: # class Test(models.Model): # courses_test # """测试学习用""& ...
- SQL常用字段类型
中文常用字段类型 1. 名称类 nvarchar(10) 2. 数量 int 3. 时间 date 4. 货币 money 5. 编号 ...
- SQL数据库中字段类型 与C#中的对应字段类型
数据库中的字段类型和对应的C#中的对应字段类型 数据库 C#程序int int32text stringbigint int64binary System.Byte[] ...
随机推荐
- 列生成算法(求解Cutting Stock问题)
列生成是用于求解大规模线性优化问题的一种算法,其实就是单纯形法的一种形式.单纯性可以通过不断迭代,通过换基变量的操作,最终找到问题的最优解.但是当问题的规模很大之后,变量的个数就会增大到在有限时间内无 ...
- 【NetWork】外网和内网
外网和内网 2019-11-16 11:22:37 by冲冲 1.内网 ① 内网的电脑们,需要经过交换机.路由器,才能访问Internet(外网). ② 因为外网IP比较紧张,现在的电脑普及使得外 ...
- C/C++ Qt TableDelegate 自定义代理组件
TableDelegate 自定义代理组件的主要作用是对原有表格进行调整,例如默认情况下Table中的缺省代理就是一个编辑框,我们只能够在编辑框内输入数据,而有时我们想选择数据而不是输入,此时就需要重 ...
- JSOI2021 酱油记
Day -24 - 2021.3.16 终于停课了(bushi)-- 稍微规划了下省选前听课的日程,大约周二(3.16)请一天,周四(3.18)请一天,周五(3.19)请半天?月考正常考,月考完请两周 ...
- Bedtools如何比较两个参考基因组注释版本的基因?
目录 问题 思路 问题 原问题来自:How to calculate overlapping genes between two genome annotation versions? 其实可分为两个 ...
- spring-boot -配置文件值注入
/** * 将配置文件中配置的每一个属性的值,映射到这个组件中 * @ConfigurationProperties:告诉SpringBoot将本类中的所有属性和配置文件中相关的配置进行绑定: 默认在 ...
- MariaDB—备份数据库
1> 备份单个数据库 mysqldump -uroot -plichao123 --database students1 > stundents.sql; 2>查看备份文件 3> ...
- Redis | 第8章 发布订阅与事务《Redis设计与实现》
目录 前言 1. 发布订阅 1.1 频道的订阅与退订 1.2 模式的订阅与退订 1.3 发送消息 1.4 查看订阅消息 2. 事务 2.1 事务的实现 2.2 WATCH 命令的实现 2.3 事务的 ...
- 强化学习实战 | 表格型Q-Learning玩井字棋(一)
在 强化学习实战 | 自定义Gym环境之井子棋 中,我们构建了一个井字棋环境,并进行了测试.接下来我们可以使用各种强化学习方法训练agent出棋,其中比较简单的是Q学习,Q即Q(S, a),是状态动作 ...
- day17 阶段测验
题目 1.找出/proc/meminfo文件中以s开头的行,至少用三种方式忽略大小写 有以下几种方法: [root@localhost ~]# grep -iE "^s" /pro ...