There is a huge performance penalty to using ENUM
for operations such as:
-
Query the list of permitted values in the
ENUM
, for instance to populate a drop-down menu. You have to query the data type fromINFORMATION_SCHEMA
, and parse the list out of a BLOB field returned. -
Alter the set of permitted values. It requires an
ALTER TABLE
statement, which locks the table and may do a restructure.
I’m not a fan of MySQL’s ENUM
. I prefer to use lookup tables. See also my answer to “How to handle enumerations without enum fields in a database?“