【MySQL】MySQL 中 ENUM 的用法

2024-08-24 18:20
文章标签 mysql 用法 database enum

本文主要是介绍【MySQL】MySQL 中 ENUM 的用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MySQL 中 ENUM 的用法

在 MySQL 中,ENUM 是一种字符串数据类型,用于列出一组预定义的值。它允许你为列指定一个有限的选项集,确保插入的数据仅限于这些选项之一。

1. 定义 ENUM 列

在创建表时,可以使用 ENUM 数据类型定义列。例如:

CREATE TABLE users (id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(100),status ENUM('active', 'inactive', 'suspended') NOT NULL
);

在这个例子中,status 列只能包含 ‘active’、‘inactive’ 或 ‘suspended’ 这三个值。

2. 插入数据

插入数据时,ENUM 列只能使用定义的值:

INSERT INTO users (name, status) VALUES ('Alice', 'active');
INSERT INTO users (name, status) VALUES ('Bob', 'inactive');

如果尝试插入一个不在定义范围内的值,会导致错误:

INSERT INTO users (name, status) VALUES ('Charlie', 'banned');  -- 错误

3. 修改 ENUM 列

可以使用 ALTER TABLE 命令修改 ENUM 列的定义。例如,添加一个新的选项:

ALTER TABLE users MODIFY status ENUM('active', 'inactive', 'suspended', 'deleted') NOT NULL;

5. 注意事项

存储:ENUM 类型的值在内部以整数形式存储,实际存储的字节数取决于定义的值的数量(最多 65535 个值)。
排序:ENUM 值的排序顺序与定义的顺序相同。
空值:如果列定义为 NOT NULL,则必须提供有效的 ENUM 值。
性能:在某些情况下,使用 ENUM 可以提高性能,因为它使用整数存储和比较。

CREATE TABLE products (id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(100),category ENUM('electronics', 'furniture', 'clothing') NOT NULL
);INSERT INTO products (name, category) VALUES ('Laptop', 'electronics');
INSERT INTO products (name, category) VALUES ('Sofa', 'furniture');

总结

ENUM 是一个方便的 MySQL 数据类型,用于限制列的值为一组预定义的字符串,确保数据的有效性和一致性。

这篇关于【MySQL】MySQL 中 ENUM 的用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1103250

相关文章

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

MySQL按时间维度对亿级数据表进行平滑分表

《MySQL按时间维度对亿级数据表进行平滑分表》本文将以一个真实的4亿数据表分表案例为基础,详细介绍如何在不影响线上业务的情况下,完成按时间维度分表的完整过程,感兴趣的小伙伴可以了解一下... 目录引言一、为什么我们需要分表1.1 单表数据量过大的问题1.2 分表方案选型二、分表前的准备工作2.1 数据评估

SQL Server 查询数据库及数据文件大小的方法

《SQLServer查询数据库及数据文件大小的方法》文章介绍了查询数据库大小的SQL方法及存储过程实现,涵盖当前数据库、所有数据库的总大小及文件明细,本文结合实例代码给大家介绍的非常详细,感兴趣的... 目录1. 直接使用SQL1.1 查询当前数据库大小1.2 查询所有数据库的大小1.3 查询每个数据库的详

Python中yield的用法和实际应用示例

《Python中yield的用法和实际应用示例》在Python中,yield关键字主要用于生成器函数(generatorfunctions)中,其目的是使函数能够像迭代器一样工作,即可以被遍历,但不会... 目录python中yield的用法详解一、引言二、yield的基本用法1、yield与生成器2、yi

深度解析Python yfinance的核心功能和高级用法

《深度解析Pythonyfinance的核心功能和高级用法》yfinance是一个功能强大且易于使用的Python库,用于从YahooFinance获取金融数据,本教程将深入探讨yfinance的核... 目录yfinance 深度解析教程 (python)1. 简介与安装1.1 什么是 yfinance?

MySQL中REPLACE函数与语句举例详解

《MySQL中REPLACE函数与语句举例详解》在MySQL中REPLACE函数是一个用于处理字符串的强大工具,它的主要功能是替换字符串中的某些子字符串,:本文主要介绍MySQL中REPLACE函... 目录一、REPLACE()函数语法:参数说明:功能说明:示例:二、REPLACE INTO语句语法:参数

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

MySQL中优化CPU使用的详细指南

《MySQL中优化CPU使用的详细指南》优化MySQL的CPU使用可以显著提高数据库的性能和响应时间,本文为大家整理了一些优化CPU使用的方法,大家可以根据需要进行选择... 目录一、优化查询和索引1.1 优化查询语句1.2 创建和优化索引1.3 避免全表扫描二、调整mysql配置参数2.1 调整线程数2.

MySQL 临时表与复制表操作全流程案例

《MySQL临时表与复制表操作全流程案例》本文介绍MySQL临时表与复制表的区别与使用,涵盖生命周期、存储机制、操作限制、创建方法及常见问题,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随小... 目录一、mysql 临时表(一)核心特性拓展(二)操作全流程案例1. 复杂查询中的临时表应用2. 临时