MySQL Enum performance advantage?

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 from INFORMATION_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?

Leave a Comment