MySQL 中 ENUM 的用法是什么

06-01 1275阅读

MySQL 中 ENUM 的用法

ENUM 是 MySQL 中一种非常有用的列数据类型,它用于定义一个枚举类型的字段。ENUM 数据类型允许字段的值从一个预定义的值集合中选择,并且可以通过限制用户输入的方式,确保数据的一致性和完整性。

一、ENUM 的定义与语法

ENUM 是 “enumeration” 的缩写,用于定义具有一组预定义值的字符串类型字段。每个 ENUM 类型的字段可以保存一个枚举值列表中的值,且每个字段最多只能存储其中的一个值。

定义 ENUM 类型字段的基本语法如下:

CREATE TABLE 表名 (
    字段名 ENUM('值1', '值2', ..., '值N') [NOT NULL | NULL] DEFAULT '默认值'
);

其中:

  • 字段名 是定义为 ENUM 类型的字段名称。
  • '值1', '值2', ..., '值N' 是枚举类型的可能值列表,每个值是一个字符串。
  • [NOT NULL | NULL] 指定字段是否允许 NULL 值。
  • DEFAULT 用于设置该字段的默认值。

    例如:

    CREATE TABLE users (
        id INT AUTO_INCREMENT PRIMARY KEY,
        status ENUM('active', 'inactive', 'banned') NOT NULL DEFAULT 'active'
    );
    

    在这个例子中,status 是一个 ENUM 类型字段,允许的值为 'active'、'inactive' 和 'banned',并且该字段的默认值是 'active'。

    二、ENUM 的特点

    1. 存储方式:

      • ENUM 类型的值以整数形式存储,而不是直接存储为字符串。每个枚举值在存储时被映射为一个从 1 开始的整数,例如 '值1' 对应 1,'值2' 对应 2,依此类推。这种存储方式使得 ENUM 类型在空间占用上比较紧凑。
      • 存储大小取决于枚举值的数量:
        • 1 个或 2 个枚举值:需要 1 个字节存储。
        • 3 到 255 个枚举值:需要 1 个字节存储。
        • 256 到 65,535 个枚举值:需要 2 个字节存储。
        • 查询时的表现:

          • 在执行查询时,ENUM 字段返回的是字符串值,而不是存储的整数。例如,如果字段的值是 'active',查询结果中会返回 'active' 而不是其对应的整数表示。
          • 默认值:

            • 可以为 ENUM 类型字段指定一个默认值,如果插入数据时该字段未明确赋值,MySQL 会使用这个默认值。例如,在上面的例子中,如果在插入用户记录时不指定 status 字段的值,它将自动默认为 'active'。

    三、ENUM 的用法

    1. 创建包含 ENUM 类型的表

    如前所述,创建包含 ENUM 类型字段的表的方式比较简单。以下是一个创建包含 ENUM 类型字段的例子:

    CREATE TABLE products (
        id INT AUTO_INCREMENT PRIMARY KEY,
        name VARCHAR(255) NOT NULL,
        category ENUM('electronics', 'furniture', 'clothing', 'toys') NOT NULL
    );
    

    在这个例子中,category 字段只能存储 'electronics'、'furniture'、'clothing' 或 'toys' 之一,插入或更新时如果试图存入其他值,会报错。

    2. 插入 ENUM 数据

    向包含 ENUM 字段的表插入数据时,只能插入预定义的值之一。以下是插入操作的例子:

    INSERT INTO products (name, category) VALUES ('Laptop', 'electronics');
    INSERT INTO products (name, category) VALUES ('Sofa', 'furniture');
    

    如果尝试插入一个不在 ENUM 列表中的值,例如:

    INSERT INTO products (name, category) VALUES ('Hat', 'accessories');
    

    MySQL 将抛出错误,提示该值无效:

    ERROR 1265 (01000): Data truncated for column 'category' at row 1
    
    3. 查询 ENUM 数据

    ENUM 类型字段的查询和普通字段一样,可以直接根据枚举值进行查询。例如:

    MySQL 中 ENUM 的用法是什么
    (图片来源网络,侵删)
    SELECT * FROM products WHERE category = 'electronics';
    

    该查询会返回所有 category 为 'electronics' 的产品。

    4. 更新 ENUM 数据

    可以使用 UPDATE 语句更新 ENUM 字段的值。例如:

    MySQL 中 ENUM 的用法是什么
    (图片来源网络,侵删)
    UPDATE products SET category = 'toys' WHERE id = 2;
    

    该操作会将 id 为 2 的产品类别更改为 'toys'。

    5. 修改 ENUM 列的值列表

    如果需要为现有的 ENUM 列添加或删除值,可以使用 ALTER TABLE 语句。例如,向 category 列中添加新类别 'accessories':

    ALTER TABLE products MODIFY category ENUM('electronics', 'furniture', 'clothing', 'toys', 'accessories');
    

    需要注意的是,在修改 ENUM 列时,新的值必须包含现有的所有值,否则现有的数据可能无法匹配新的枚举列表,导致数据不一致。

    四、ENUM 的优缺点

    1. 优点
    • 数据完整性:ENUM 类型强制数据只能在预定义的列表中选择,避免了存入非法值的情况。这对数据一致性和完整性有很大帮助,尤其是在用户输入不可控的情况下。
    • 存储效率:ENUM 值在 MySQL 中以整数形式存储,空间占用非常少,尤其当枚举值数量较少时,存储效率高。
    • 代码可读性:使用 ENUM 可以使代码和数据结构更加清晰,程序员和维护人员可以从数据库结构中很容易地看到一个字段允许的值范围,提升了代码和数据库表设计的可读性。
      2. 缺点
      • 扩展性差:一旦定义了 ENUM 类型,如果需要添加新的枚举值,必须使用 ALTER TABLE 修改表结构。对于大表来说,修改表结构可能会影响性能。如果应用需求中枚举值的变化较频繁,ENUM 类型可能不适合。
      • 限制性:ENUM 类型只适用于值范围固定且相对较小的字段。如果有更复杂的需求(例如支持多选),ENUM 不适合使用。
      • 查询复杂性:ENUM 的底层存储为整数,而查询返回的是字符串。因此在一些情况下,特别是涉及数值比较时,可能会产生混淆。

        五、ENUM 与其他数据类型的比较

        ENUM 类型在处理一组固定值时非常有用,但与其他一些常见的数据类型相比,它有一些独特的特点。

        1. ENUM vs. VARCHAR

        ENUM 和 VARCHAR 都可以用于存储字符串,但它们有明显的区别:

        • 数据完整性:ENUM 强制字段的值只能在预定义的列表中选择,而 VARCHAR 没有这种约束,用户可以输入任意值。
        • 存储效率:ENUM 使用整数存储,效率更高,而 VARCHAR 则根据字符串的实际长度动态分配存储空间,可能会占用更多空间。
          2. ENUM vs. SET

          SET 是 MySQL 中的另一种特殊类型,允许字段保存多个预定义的值,而 ENUM 则限制为一个值。

          • 单值 vs. 多值:ENUM 只能保存单个值,而 SET 允许保存多个值。
          • 适用场景:如果需要表示某个字段的多种状态或多种属性,使用 SET 更为合适;而如果字段仅有单一的状态或属性,ENUM 更合适。

            六、ENUM 的实际使用场景

            1. 用户状态:ENUM 可以用于表示用户的状态,如 active、inactive、banned。

              CREATE TABLE users (
                  id INT AUTO_INCREMENT PRIMARY KEY,
                  username VARCHAR(50),
                  status ENUM('active', 'inactive', 'banned') NOT NULL DEFAULT 'active'
              );
              
            2. 订单状态:用于表示订单的不同状态,如 pending、shipped、delivered、canceled。

              CREATE TABLE orders (
                  id INT AUTO_INCREMENT PRIMARY KEY,
                  product_id INT,
                  status ENUM('pending', 'shipped', 'delivered', 'canceled') NOT NULL DEFAULT 'pending'
              );
              
            3. **性

            别字段**:在数据库设计中,有时需要保存性别信息,常见的选项为 'male' 和 'female',可以使用 ENUM 来定义。

            CREATE TABLE employees (
                id INT AUTO_INCREMENT PRIMARY KEY,
                name VARCHAR(50),
                gender ENUM('male', 'female') NOT NULL
            );
            

            七、总结

            MySQL 中的 ENUM 数据类型适用于定义有限的、预定义的值集合,它可以有效地确保数据一致性,减少非法数据输入,且具有较高的存储效率。然而,ENUM 的扩展性较差,适用于值列表不经常变化的场景。在设计数据库时,需要根据实际需求权衡 ENUM 的优缺点,合理使用。

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们。

目录[+]

取消
微信二维码
微信二维码
支付宝二维码