技术文摘
在 MySQL 表中使用 CREATE TABLE 语句创建多个虚拟生成列的方法
在 MySQL 表中使用 CREATE TABLE 语句创建多个虚拟生成列的方法
在数据库管理中,MySQL 的虚拟生成列功能为开发者提供了强大而灵活的数据处理方式。虚拟生成列并非存储实际数据,而是基于其他列的数据通过表达式计算得出,这不仅节省了存储空间,还能提高数据一致性和查询效率。接下来,我们就详细探讨如何使用 CREATE TABLE 语句创建多个虚拟生成列。
明确创建虚拟生成列的基本语法。CREATE TABLE 语句用于创建新表,其基本结构为:CREATE TABLE 表名 (列定义); 当涉及虚拟生成列时,列定义的语法格式为:列名 数据类型 GENERATED ALWAYS AS (表达式) [VIRTUAL | STORED]。其中,VIRTUAL 表示虚拟生成列(默认),数据不实际存储;STORED 则表示存储生成列,数据会被实际存储。
假设我们要创建一个员工信息表 employees,包含员工编号 emp_id、基本工资 basic_salary、奖金 bonus,同时希望创建两个虚拟生成列:总薪资 total_salary(基本工资与奖金之和)和年度总薪资 annual_salary(总薪资乘以 12)。具体的 CREATE TABLE 语句如下:
CREATE TABLE employees (
emp_id INT PRIMARY KEY,
basic_salary DECIMAL(10, 2),
bonus DECIMAL(10, 2),
total_salary DECIMAL(12, 2) GENERATED ALWAYS AS (basic_salary + bonus) VIRTUAL,
annual_salary DECIMAL(13, 2) GENERATED ALWAYS AS (total_salary * 12) VIRTUAL
);
在上述代码中,首先定义了常规列 emp_id、basic_salary 和 bonus。然后,通过 GENERATED ALWAYS AS 子句分别定义了两个虚拟生成列 total_salary 和 annual_salary。total_salary 通过 basic_salary 与 bonus 相加得出,而 annual_salary 则基于 total_salary 进一步计算。
值得注意的是,虚拟生成列的表达式可以是复杂的数学运算、字符串操作或函数调用等。并且,生成列依赖的基础列数据发生变化时,虚拟生成列会自动重新计算。
通过这种方式,在 MySQL 表中利用 CREATE TABLE 语句创建多个虚拟生成列,能够让数据库结构更加清晰,数据处理更加高效,为开发者在数据库设计和管理上提供极大便利,助力项目的稳定运行与持续发展。
TAGS: 创建方法 MySQL表 CREATE TABLE语句 虚拟生成列
- Vue.js 中获取登录用户文章列表的方法
- Block Nested-Loop Join 算法怎样优化 Nested-Loop Join 算法的扫描次数
- 深入解读 MySQL 数字数据类型
- MySQL 怎样检索当日数据
- SQL 怎样在更新操作里忽略唯一键冲突
- SQL语句参数化查询写法:正确传递参数与规避子查询错误的方法
- Spring Boot 与 MyBatis 中怎样优雅查询不同数据类型记录
- MySQL 中怎样在长地址里模糊查询匹配镇区
- 数据库事务回滚后自增 ID 出现断裂的原因
- MySQL 批量修改数据的方法
- Ambari命名来源:是否源于印度语的“象轿”
- 海量对象-属性-值三元组高效存储与快速搜索方法
- SQL 如何将设备类别名称填充至设备表
- MySQL Block Nested-Loop Join (BNL) 算法中一次性与 100 行数据比较的实现方式
- 海量对象-属性-值三元组的高效存储与搜索方法