MySQL is a powerful database management system that offers a wide range of features to make it easy for developers to work with data. One of the many features available is generated columns, which can help to automate certain tasks and calculations.
In this post, we're going to look at what generated columns are, how to use them, and some common use cases.
Generated columns are a way to make MySQL do more work on your behalf, by allowing you to create columns that are based on other columns in your table. Essentially, a generated column is a column that is computed by an expression, rather than being explicitly stored in the table.
The idea is that you can define a column using a formula or calculation, and MySQL will automatically calculate the values for that column based on the data in other columns.
Let's take a look at an example of how to create a table with generated columns. In this example, we're going to create a table called
emails, which will have two columns -
domain column will be generated based on the contents of the
To create the generated column, we'll use the
AS keyword and a function called
substring index. The
substring index function allows us to extract the domain from the email address.
Here's what the SQL code looks like:
CREATE TABLE emails (
domain varchar(255) AS (substring_index(email, '@', -1))
Notice that the
domain column is defined as
varchar(255) AS (substring_index(email, '@', -1)). This means that the value of the
domain column will be computed based on the contents of the
One important thing to note about generated columns is that they can be either virtual or stored.
A virtual column is calculated at runtime and does not take up any space on the disk. This means that it may take longer to calculate, but it doesn't impact the overall size of the table.
A stored column, on the other hand, is calculated during data insertion or update and saved to disk, just like a regular column. This means that it might be faster to retrieve data from a stored column, but it will take up more space on the disk.
When creating a generated column, you can specify whether it should be virtual or stored by using the
STORED keyword. If you don't specify anything, the column will default to being virtual.
There are many potential use cases for generated columns. Here are a few examples:
Extracting data from JSON objects - If you have a column that contains a big JSON blob, you can use a generated column to extract a specific key from the blob and create a new column with just that data. This can make it easier to query the data and improve performance.
Performing calculations - You can use generated columns to perform calculations such as converting units, applying tax rates, and more. This can be useful for creating reports or performing other data analysis tasks.
Normalizing data - If you have a column that contains redundant data, you can use a generated column to extract that data and create a new table with just the unique values. This can make it easier to manage your data and eliminate redundancy.
Generated columns are a powerful feature of MySQL that can help you automate certain tasks and calculations. By defining a column using a formula or calculation, you can save yourself time and effort, and ensure that your data is always up-to-date.
In this post, we covered the basics of generated columns, including how to create them, the differences between virtual and stored columns, and some common use cases. We hope you found this post informative and useful, and that you'll consider using generated columns in your own MySQL database.
About this lesson
MySQL can calculate values on the fly for you, based on an expression. These can be extremely powerful in many circumstances.
I’m a dad to one-year-old twins and a software developer with a keen interest in processes and automation.
Feedback or questions? Reach out to our team at email@example.com.