MySQL存储的GENERATED COLUMNS与MySQL虚拟的GENERATED COLUMNS有何不同?

以下是MySQL存储的GENERATED COLUMNS和MySQL虚拟的GENERATED COLUMNS之间的一些基本区别-

在磁盘空间方面

如果我们看到磁盘空间方面的差异,那么虚拟生成的列将不会占用任何磁盘空间。另一方面,存储的生成列将占用磁盘空间。

在操作方面

如果我们看到操作方面的差异,那么虚拟生成的列就是INPLACE操作,这意味着更改了表定义,而不必再次重新复制所有数据。另一方面,存储的生成的列是复制操作,并且其成本与向表中添加新列的成本相同。

在计算方面

 在虚拟生成的列中,这些值是在读取操作和触发之前动态计算的。另一方面,在存储的生成列中,每个INSERT和UPDATE语句中的值都会更新。

何时使用

我们应该考虑使用虚拟列来存储发生大量更改的数据。虚拟列的成本来自不断读取表,服务器每次都要计算该列的值。另一方面,当数据变化不大或创建后根本没有变化时,我们应该考虑使用“存储列”。

猜你喜欢