MySQL存储的GENERATED COLUMNS与MySQL虚拟的GENERATED COLUMNS有何不同?
以下是MySQL存储的GENERATEDCOLUMNS和MySQL虚拟的GENERATEDCOLUMNS之间的一些基本区别-
在磁盘空间方面
如果我们看到磁盘空间方面的差异,那么虚拟生成的列将不会占用任何磁盘空间。另一方面,存储的生成列将占用磁盘空间。
在操作方面
如果我们看到操作方面的差异,那么虚拟生成的列就是INPLACE操作,这意味着更改了表定义,而不必再次重新复制所有数据。另一方面,存储的生成的列是复制操作,并且其成本与向表中添加新列的成本相同。
在计算方面
在虚拟生成的列中,这些值是在读取操作和触发之前动态计算的。另一方面,在存储的生成列中,每个INSERT和UPDATE语句中的值都会更新。
何时使用
我们应该考虑使用虚拟列来存储发生大量更改的数据。虚拟列的成本来自不断读取表,服务器每次都要计算该列的值。另一方面,当数据变化不大或创建后根本没有变化时,我们应该考虑使用“存储列”。
热门推荐
10 分别发的祝福语简短
11 大外甥高考祝福语简短
12 小学毕业校长简短祝福语
13 搞工程发财祝福语简短
14 冬季祝福语男生文案简短
15 同事生子问候祝福语简短
16 退休文案寄语简短祝福语
17 送给自己的祝福语简短
18 简短祝福语毛笔字