A Comprehensive Guide to Using MySQL ENUM

A Comprehensive Guide to Using MySQL ENUM

 A Comprehensive Guide to Using MySQL ENUM



Summary: in this tutorial, you will learn how to use MySQL ENUM the data type for defining columns that store enumeration values.

Introduction to MySQL ENUM data type

In MySQL, an ENUM is a string object whose value is chosen from a list of permitted values defined at the time of column creation.

The ENUM datatype provides the following advantages:

  • Compact data storage. MySQL ENUM uses numeric indexes (1, 2, 3, …) to represents string values.
  • Readable queries and output.

To define an ENUM column, you use the following syntax:

CREATE TABLE table_name ( ... col ENUM ('value1','value2','value3'), ... );

In this syntax, you can have more than three enumeration values. However, it is a good practice to keep the number of enumeration values under 20.

Let’s see the following example.

Suppose, we have to store ticket information with the priority: low, medium, and high. To assign the priority column the ENUM type, you use the following CREATE TABLE statement:

CREATE TABLE tickets ( id INT PRIMARY KEY AUTO_INCREMENT, title VARCHAR(255) NOT NULL, priority ENUM('Low', 'Medium', 'High') NOT NULL );

The priority the column will accept only three values LowMedium and High. Behind the scenes, MySQL maps each enumeration member to a numeric index. In this case, LowMedium, and High are a map to 1, 2, and 3 respectively.

Inserting MySQL ENUM values

To insert data into an ENUM column, you use the enumeration values in the predefined list. For example, the following statement inserts a new row into the tickets table.

INSERT INTO tickets(title, priority) VALUES('Scan virus for computer A', 'High');

Besides the enumeration values, you can use the numeric index of the enumeration member for inserting data into an ENUM column. For instance, the following statement inserts a new ticket with the Low priority:

INSERT INTO tickets(title, priority) VALUES('Upgrade Windows OS for all computers', 1);

In this example, instead of using the Low enumeration value, we used value 1. Since Low is mapped to 1, it is acceptable.

Let’s add some more rows to the tickets table:

INSERT INTO tickets(title, priority) VALUES('Install Google Chrome for Mr. John', 'Medium'), ('Create a new user for the new employee David', 'High');

Because we defined the priority as a NOT NULL column, when you insert a new row without specifying the value for the priority column, MySQL will use the first enumeration member as the default value.

See the following statement:

INSERT INTO tickets(title) VALUES('Refresh the computer of Ms. Lily');

In the non-strict SQL mode, if you insert an invalid value into an ENUM column, MySQL will use an empty string '' with the numeric index 0 for inserting. In case the strict SQL mode is enabled, trying to insert an invalid ENUM the value will result in an error.

Note that an ENUM column can accept NULL values if it is defined as a null-able column.

Filtering MySQL ENUM values

The following statement gets all high priority tickets:

SELECT * FROM tickets WHERE priority = 'High';

Because the enumeration member ‘High’ is mapped to 3, the following query returns the same result set:

SELECT * FROM tickets WHERE priority = 3;

Sorting MySQL ENUM values

MySQL sorts ENUM values based on their index numbers. Therefore, the order of members depends on how they were defined in the enumeration list.

The following query selects the tickets and sorts them by priority from High to Low:

SELECT title, priority FROM tickets ORDER BY priority DESC;

It’s always a good practice to define the enumeration values in the order that you want to sort when you create the column.

MySQL ENUM disadvantages

MySQL ENUM has the following disadvantages:

  1. Changing enumeration members requires rebuilding the entire table using the ALTER TABLE the statement, which is expensive in terms of resources and time.
  2. Getting the complete enumeration list is complex because you need to access the information_schema database:
    SELECT 
        column_type
    FROM
        information_schema.COLUMNS
    WHERE
        TABLE_NAME = 'tickets'
            AND COLUMN_NAME = 'priority';
    
  3. Porting to other RDBMS could be an issue because ENUM is not SQL-standard and not many database systems support it.
  4. Adding more attributes to the enumeration list is impossible. Suppose you want to add a service agreement for each priority e.g., High (24h), Medium (1-2 days), Low (1 week), it is not possible with ENUM. In this case, you need to have a separate table for storing priority list e.g., priorities(id, name, sort_order, description), and replace the priority field in the tickets table by priority_id that references to the id field of the priorities table.
  5. Compared to the look-up table (priorities), an enumeration list is not reusable. For example, if you want to create a new table named tasks and want to reuse the priority list, it is not possible.

In this tutorial, we have introduced you to MySQL ENUM datatype and how to use it for defining columns that store enumeration values.

Reactions

Post a Comment

0 Comments

close