首页
学习
活动
专区
工具
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数据库中定义相应的枚举类型。

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

相关·内容

MySQL中ENUM类型学习--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的第一个值”?…「建议收藏」

    刚刚在看MySQL>>一书的”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

    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...同样,enum在mysql手册上的说明: 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会为这些默认应用程序创建必要的数据库表。 创建模型 在创建模型之前我们需要知道这个模型属于哪一个应用下的。

    9610

    在 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.2K10

    如何在 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 处相交。线性方程法:另一种方法是将列表中的元素视为线段,使用线性方程求解线段相交点。我们可以构造一个线性方程组,其中每个方程代表列表中的一条线段。

    13310

    Django-bootstrap3|在Django中快速使用Bootstrap模版

    前言 关于如何快速基于Django使用别人写好的模版搭建网站之前已经有详细讲过,一般我们在Django中使用Bootstrap模版都需要经过以下几个步骤 下载一个Bootstrap模版 创建app并粘贴模板到对应的的...templates文件夹中 修改settings.py、urls.py、views.py等文件 创建static文件夹并修改相关css、js文件中的链接跳转 启动Django 最近在逛GitHub时发现一个名为...Python版本> = 3.5 Django版本> = 2.1 如果你的环境不满足需要先进行升级,在相关环境及依赖配置好后后,只需要在settings.py文件中的INSTALLED_APPS中添加'bootstrap3...接着将整个模版复制粘贴至app文件夹下,并修改views.py视图函数,比如我的模版中只有一个index.html from django.views.generic.base import TemplateView...class HomePageView(TemplateView): template_name = "app/index.html" 接着去将该页面添加至urls.py中 from django.conf.urls

    5.9K20

    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

    在Django中使MySQL支持存储Emoji表情????

    当我们在Django应用程序中使用MySQL数据库时,可能会遇到无法存储包含Emoji表情的数据的问题。...这是因为MySQL默认字符集和校对规则只支持存储基本的Unicode字符集,无法支持Emoji表情字符。在这篇博客中,我将为您介绍如何在Django中使MySQL支持存储Emoji表情。...在MySQL的默认字符集utf8中,只支持3个字节的Unicode字符,而Emoji表情字符通常需要4个字节。...修改Django配置 在Django的settings.py文件中,我们需要进行以下设置(主要是charset的配置项): DATABASES = { 'default': {...支持存储Emoji表情需要我们进行多个步骤,包括修改MySQL的字符集和校对规则、Django的设置以及模型定义。

    95830
    领券