True/False vs 0/1 in MySQL

Some “front ends”, with the “Use Booleans” option enabled, will treat all TINYINT(1) columns as Boolean, and vice versa.

This allows you to, in the application, use TRUE and FALSE rather than 1 and 0.

This doesn’t affect the database at all, since it’s implemented in the application.

There is not really a BOOLEAN type in MySQL. BOOLEAN is just a synonym for TINYINT(1), and TRUE and FALSE are synonyms for 1 and 0.

If the conversion is done in the compiler, there will be no difference in performance in the application. Otherwise, the difference still won’t be noticeable.

You should use whichever method allows you to code more efficiently, though not using the feature may reduce dependency on that particular “front end” vendor.

Leave a Comment