MySQL虚拟列详解
warning:
这篇文章距离上次修改已过440天,其中的内容可能已经有所变动。
MySQL虚拟列是MySQL 5.7版本引入的新特性,它允许你在存储的时候不实际存储一个计算列,而是在查询时动态生成。这样可以提高查询的效率,并且减少了存储数据所需的空间。
创建虚拟列的基本语法如下:
ALTER TABLE table_name
ADD COLUMN (column_name data_type GENERATED ALWAYS AS (expression)) VIRTUAL;其中,table_name 是你要修改的表名,column_name 是你要添加的虚拟列名,data_type 是虚拟列的数据类型,expression 是计算虚拟列值的表达式。
例如,假设我们有一个名为 employees 的表,其中包含 first_name 和 last_name 两个列,我们想要创建一个虚拟列 full_name,它是 first_name 和 last_name 的拼接。
ALTER TABLE employees
ADD COLUMN full_name VARCHAR(255) GENERATED ALWAYS AS (CONCAT(first_name, ' ', last_name)) VIRTUAL;在这个例子中,我们创建了一个虚拟列 full_name,它会在查询时动态生成,不会占用额外的存储空间。
查询虚拟列的例子:
SELECT full_name FROM employees;这将会返回所有员工的全名,由MySQL动态生成。
注意:虚拟列不能用于索引或者在有子查询的查询中。
评论已关闭