mysql的填充因子_数据库的索引和填充因子fillfactor

本文详细介绍了数据库中的聚簇索引和非聚簇索引,解释了它们的存储方式和区别。聚簇索引决定了数据的物理存储顺序,而非聚簇索引则与数据物理顺序无关。填充因子是一个在创建索引时设置的参数,用于控制索引页的填充程度,以减少页拆分和优化性能。适当的填充因子设置对于读写密集型应用至关重要,因为它影响了数据库的读取和写入速度。在创建索引时,需要根据表数据的变化情况来调整填充因子的值。
摘要由CSDN通过智能技术生成

索引分为聚簇索引和非聚簇索引

1.聚簇索引/聚集索引

聚簇索引的顺序就是数据的物理存储顺序,对于一个表来说,只有一个聚簇索引

create unique clustered indexid_indexon table_1(id asc)with

fillfactor=10 /*填充因子10%*/

2.非聚簇索引/非聚集索引

聚簇索引的顺序跟数据的物理顺序无关,索引与数据存放在不同的物理区域,建立非聚簇索引时数据本身不进行排序,一个表中可含多个非聚簇索引。

create nonclustered indexid_datetimes_indexon table_1(id asc,datetimes asc)with

fillfactor=10 /*填充因子10%*/

3.填充因子fillfactor

在创建聚集索引时,表中的数据按照索引列中的值的顺序存储在数据库的数据页中。在表中插入新的数据行或更改索引列中的值 时,可能必须重新组织表中的数据存储,以便为新行腾出空间,保持数据的有序存储。这同样适用于非聚集索引。添加或更改数据时,SQL   Server   可能不得不重新组织非聚集索引页中的数据存储。向一个已满的索引页添加某个新行时,SQL   Server   把大约一半的行移到新页中以便为新行腾出空间。这种重组称为页拆分。页拆分会降低性能并使表中的数据存储产生碎片。有关更多信息,请参见表和索引构架。

创建索引时,可以指定一个填充因子,以便在索引的每个叶级页上留出额外的间隙和保留一定百分比的空间,供将来表的数据存储容量进行扩充和减少页拆分的可能 性。填充因子的值是从   0   到   100   的百分比数值,指定在创建索引后对数据页的填充比例。值为   100   时表示页将填满,所留出的存储空间量最小。只有当不会对数据进行更改时(例如,在只读表中)才会使用此设置。值越小则数据页上的空闲空间越大,这样可以减 少在索引增长过程中对数据页进行拆分的需要,但需要更多的存储空间。当表中数据会发生更改时,这种设置更为适当。

提供填充因子选项是为了对性能进行微调。但是,使用   sp_configure   系统存储过程指定的服务器范围的默认填充因子,在大多数情况下都是最佳的选择。

说明即使对于一个面向许多插入和更新操作的应用程序来说,数据库读取次数一般也超过数据库写入次数的   5   到   10   倍。因此,指定一个不同于默认设置的填充因子会降低数据库的读取性能,而降低量与填充因子设置值成反比。例如,当填充因子的值为   50%   时,数据库的读取性能会降低两倍。

只有当在表中根据现有数据创建新索引,并且可以精确预见将来会对这些数据进行哪些更改时,将填充因子选项设置为另一个值才有用。

填充因子只在创建索引时执行;索引创建后,当表中进行数据的添加、删除或更新时,不会保持填充因子。如果试图在数据页上保持额外的空间,则将有背于使用填 充因子的本意,因为随着数据的输入,SQL   Server   必须在每个页上进行页拆分,以保持填充因子指定的空闲空间百分比。因此,如果表中的数据进行了较大的变动,添加了新数据,可以填充数据页的空闲空间。在这 种情况下,可以重新创建索引,重新指定填充因子,以重新分布数据。

因此,一般设置的原则是数据变化较大,填充因子设较小值,而数据变化较小,填充因子设较大值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值