首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在Django模型中指定mySQL ENUM

在Django模型中指定mySQL ENUM类型时,可以使用choices参数来定义枚举值。

首先,需要在Django模型中定义一个字段,并将其类型设置为CharField,然后使用choices参数来定义枚举值。例如,如果要在Django模型中定义一个名为status的字段,其类型为mySQL ENUM,可以按照以下方式定义:

代码语言:python
代码运行次数:0
复制
from django.db import models

class MyModel(models.Model):
    STATUS_CHOICES = (
        ('A', 'Active'),
        ('I', 'Inactive'),
        ('D', 'Deleted'),
    )
    status = models.CharField(max_length=1, choices=STATUS_CHOICES, default='A')

在上面的例子中,STATUS_CHOICES定义了三个枚举值:A表示Active,I表示Inactive,D表示Deleted。status字段的类型为CharField,并且使用choices参数将其设置为枚举类型。

在使用Django模型时,可以使用status字段的名称来访问枚举值。例如,可以使用MyModel.objects.filter(status='A')来查询所有状态为Active的记录。

需要注意的是,在使用mySQL ENUM类型时,需要确保在mySQL数据库中定义相应的枚举类型。可以使用以下SQL语句来定义枚举类型:

代码语言:sql
复制
CREATE TYPE status_enum AS ENUM ('A', 'I', 'D');

然后,在创建表时,可以将status字段的类型设置为status_enum

总之,在Django模型中指定mySQL ENUM类型时,可以使用choices参数来定义枚举值,并确保在mySQL数据库中定义相应的枚举类型。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQLENUM类型学习--MySql语法

ENUM是一个字符串对象,其值来自表创建时列规定显式枚举的一列值。...某些情况下,ENUM值也可以为空字符串('')或NULL: · 如果你将一个非法值插入ENUM(也就是说,允许的值列之外的字符串),将插入空字符串以作为特殊错误值。...这说明你可以使用下面的SELECT语句来找出分配了非法ENUM值的行: · mysql> SELECT * FROM tbl_name WHERE enum_col=0;...例如,你可以这样从ENUM列搜索数值值: mysql> SELECT enum_col+0 FROM tbl_name; 如果将一个数字保存到ENUM列,数字被视为索引,并且保存的值是该索引对应的枚举成员...例如,下面的列含有字符串值'0'、'1'和'2'的枚举成员,但数值索引值为1、2和3: numbers ENUM('0','1','2') 根据枚举成员列定义列出的顺序对ENUM值进行排序。

1.4K20

MySQL枚举类型enum字段插入不在指定范围的值时, 是否是”插入了enum的第一个值”?…「建议收藏」

刚刚在看>一书的”ENUM类型”一节, 以下面的代码举例, 得出结论: “还可以看出对于不在ENUM指定范围内的值时, 并没有返回警告, 而是插入了enum(‘M’, ‘F’)的第一个值...还是因为MySQL的版本问题呢 mysql> create table test(gender enum('M', 'F')); Query OK, 0 rows affected (0.12 sec)...这个相当于是一个警告信息,我本地测试的 5.7 ,直接插入会报错,但是使用 ignore 后,数据能被强制插入,但是是空值。...INSERT ignore INTO user (sex) VALUES (5); 服务器使用 MySQL 5.5 测试 无论是否添加 ignore 数据都能被插入,但是是空值。... MySQL 枚举类型的“八宗罪” 这篇文章的第七条,文中提到了,如果不合法会被处理成空字符串,在后一段又提到了因为类型的缘故,会根据枚举索引去取值。

1.8K20

脚本单独使用django的ORM模型详解

有时候测试django中一些模块时,不想重新跑一整个django项目,只想跑单个文件,正好写在if __name__ == ‘__main__’: 这样也不会打扰到正常的代码逻辑 方法 正常方法 大家都知道的方法就是...’python manage.py shell’,当然我知道这可能不是你需要的; 更好用的方法 脚本import模型前调用下面几行即可: import os, sys BASE_DIR = os.path.dirname...))) os.environ.setdefault("DJANGO_SETTINGS_MODULE", "dj_tasks.settings") # 你的django的settings文件 接下来再调用...导入models的时候,还没有django对应的环境下导入 这里导入的顺序很重要 import os import django os.environ.setdefault('DJANGO_SETTINGS_MODULE...以上这篇脚本单独使用django的ORM模型详解就是小编分享给大家的全部内容了,希望能给大家一个参考。

4.8K10

MySQL enum 插入的时候注意事项

今天执行开发发过来的工单的时候,source批量导入执行时候发现报了很多警告 提示 truncate for column xxxxx 。...后来发现是enum字段没有加引号搞的鬼。 结论:    enum的字段,插入的时候,必须带上引号。否则会出现不可预期的问题。...如果不带引号插入的话,实际上是插入的key(如上面的例子 INSERT INTO t1 (b) VALUES (4),插入的是b列第四个default值,也就是取enum('4','3','2','1...utm_source=tuicool&utm_medium=referral) 在建立enum类型的字段时,我们会给他规定一个范围比如 enum('a','b','c'),这时mysql内部会建立一张hash...同样,enummysql手册上的说明: ENUM('value1','value2',...) 1或2个字节,取决于枚举值的个数(最多65,535个值) 除非enum的个数超过了一定数量,否则他所占的存储空间也总是

1.1K31

Django模型入门教程-操作MySQL

Django 为我们提供了一种更简单的操作数据库的方式。 Django 模型(Model)是用来定义数据库结构的类。每个模型类通常对应数据库的一个表,类的属性对应表的列。...数据库和面向对象的对应关系: 数据表 - 类 数据行 - 对象 字段 - 属性 配置MySQL数据库 Django 默认使用的数据库是 SQLite,而在我们这边很多中小企业喜欢用 MySQL,所以使用...配置之前,需要先安装好 MySQL ,下载地址:dev.mysql.com/downloads/m… 安装好 MySQL 后, Django 项目中打开 settings.py 文件,DATABASES...我自己电脑的用户名和密码都设置得比较简单,在生产环境千万别设置这么简单的账号密码。 安装 PyMySQL Django ,默认使用的 MySQL 数据库连接库是 MySQLdb 。...这些表的迁移文件已经包含在 Django框架,当执行迁移时,Django会为这些默认应用程序创建必要的数据库表。 创建模型 创建模型之前我们需要知道这个模型属于哪一个应用下的。

8310

PostgreSQL 解码 Django Session

存储和缓存的方案也有多种:你可以选择直接将会话存储 SQL 数据库,并且每次访问都查询一下、可以将他们存储例如 Redis 或 Memcached 这样的缓存、或者两者结合,在数据库之前设置缓存引擎...如果你使用这些最终将会话存储 SQL 的方案,则 django_session 表将存储你的用户会话数据。 本文中的截图来自 Arctype。...这就是你可以一个 Django 请求访问 request.user 的原因。...然而, Postgres 如果你尝试解析一个非法 JSON 文本,Postgres 会抛出一个错误并终止你的查询。我自己的数据库,有一些会话数据不能被作为 JSON 解析。...带有 BOTH 的 TRIM 函数会将指定的字符从字符串的两端去除,留下可以轻松转换为整数类型的干净的字符串。

3.2K20

PHP如何为匿名函数指定this?

PHP如何为匿名函数指定this? 关于闭包匿名函数,JS中有个很典型的问题就是要给它绑定一个 this 作用域。...错误信息是:使用了 $this 但是没有对象上下文,也就是说没有指定 $this 引用的作用域。...其中, $lily 参数是一个 object $newthis 参数,也就是给这个复制出来的匿名函数指定 $this 。...而第二个参数 'Lily' 则是绑定一个新的 类作用域 ,它代表一个类型、决定在这个匿名函数能够调用哪些 私有 和 受保护 的方法,上例给出的三种方式都可以用来定义这个参数。...当然,这也是看我们自己的业务情况了,毕竟两种形式我们写代码的时候都是可以自由选择的。 总结 其实包括闭包函数在内,这些特性都非常像JS。

2.1K10

如何在 Django 测试模型表单

clean user_profile = self.instance.user_profile File "/usr/local/lib/python2.7/dist-packages/django...解决方案根据错误信息,可以发现问题是 FilterForm 是一个绑定表单,需要有一个模型实例作为上下文。测试用例,没有为 FilterForm 设置模型实例。...为了解决这个问题,可以测试用例添加以下代码:filterform = FilterForm()#print filterform.is_valid()form_data = {'keyword':...替换为一个有效的模型实例。...因此,我们找到这两个列表索引 3 和 4 处相交。线性方程法:另一种方法是将列表的元素视为线段,使用线性方程求解线段相交点。我们可以构造一个线性方程组,其中每个方程代表列表的一条线段。

12010

django 模型的计算字段实例

verbose_name='姓') given_name = models.CharField(max_length=20, verbose_name='名') def name(self): # 计算字段要显示修改页面只能定义只读字段...admin.ModelAdmin): def name(self,obj): # 这个方法会得到两个参数,第一个是类本身的一个实例(app.PersonAdmin),第二个是这个类管理的模型实例...如何在 search_fields 包含外键字段 search_fields中加入一个外键的名字是不能查询的,要写成(外键名__外键的字段名)的形式. search_fields = ('attributename...','goodsclass__cn') # goodsclass__cn 就可以搜索外键的名字中有搜索词的条目了, # 比如搜索手机的分辨率,而不是电脑的分辨率,就可以搜索'手机 分辨率' 以上这篇django...模型的计算字段实例就是小编分享给大家的全部内容了,希望能给大家一个参考。

4.4K20

Django 模型自定义Manager和模型方法

1.自定义管理器(Manager) 语句Book.objects.all(),objects是一个特殊的属性,通过它来查询数据库,它就是模型的一个Manager....每个Django模型至少有一个manager,你可以创建自定义manager以定制数据库的访问....Django将会把第一个Manager 定义为默认Manager ,Django的许多部分(但是不包括admin应用)将会明确地为模型使用这个manager。...如果您在方法定义中使用了*args, **kwargs,您将保证您的代码添加时将自动支持这些参数。...上面的示例,clean()引发的ValidationError异常通过一个字符串实例化,所以它将被保存在一个特殊的错误字典,键为NON_FIELD_ERRORS.这个键用于整个模型出现的错误而不是一个特定字段穿线的错误

2.8K20

VBA:获取指定数值指定一维数组的位置

文章背景:采用VBA抓取数据时,有时需要判断指定数值是否一维数组已存在;如果存在,则希望能够获取该数值在数组内的位置。...实践过程中发现,VBA的filter函数无法完全匹配指定数值;而借助Excel的match函数,可以实现完全匹配。接下来分别对Filter函数和Match函数进行介绍。...Filter 函数 根据指定的筛选准则,传回包含字串阵列子集的以零为基础的阵列。...应用示例: 判断某字符串是否一维数组内存在。 由上图可以看出,采用Filter函数匹配到的是包含A-1的所有元素。而在实际案例,可能希望只获得完全匹配的元素。...WorksheetFunction.Match 方法 傳回項目陣列的相對位置,其符合指定順序指定值。

7.1K30
领券