登录
首页 >  数据库 >  MySQL

MySQL 存储的生成列与 MySQL 虚拟生成列有何不同?

来源:tutorialspoint

时间:2023-08-27 14:17:36 281浏览 收藏

数据库不知道大家是否熟悉?今天我将给大家介绍《MySQL 存储的生成列与 MySQL 虚拟生成列有何不同?》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!

以下是MySQL存储生成列和MySQL虚拟生成列之间的一些基本区别:

在磁盘空间方面

如果从磁盘空间的角度来看,虚拟生成列不会占用任何磁盘空间。另一方面,存储生成列会占用磁盘空间。

在操作方面

如果从操作的角度来看,虚拟生成列是原地操作,这意味着表定义被更改时不需要重新复制所有数据。另一方面,存储生成列是复制操作,其成本与向表中添加新列的成本相同。

在计算方面

 在虚拟生成列中,值是在读取操作和BEFORE触发器期间动态计算的。另一方面,在存储生成列中,值在每个INSERT和UPDATE语句中更新。

何时使用

我们应该考虑在数据中使用虚拟列,其中变化发生的次数相当多。虚拟列的成本来自于不断读取表,并且服务器每次都必须计算该列的值。另一方面,我们应该考虑在数据在创建后不会发生显着或根本不变化的情况下使用存储列。

今天关于《MySQL 存储的生成列与 MySQL 虚拟生成列有何不同?》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:tutorialspoint 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>