スケーラブルデータベースサーバ HiRDB Version 8 システム運用ガイド(UNIX(R)用)
HiRDBのインデクスはB-tree構造をしています。このため,インデクスページにキーを追加しようとした場合,追加するインデクスページに空き領域がないとき,インデクスページスプリットが発生します。インデクスページスプリットとは,キーを追加するインデクスページに空き領域がないとき,HiRDBが空き領域を確保するために,このインデクスページのインデクス情報を均等に2分割して,後ろの半分を新しいページに移すことです。通常のインデクスページスプリットの例を次の図に示します。
図14-2 インデクスページスプリットの例
表にインデクスがある場合,表に対してデータを追加すると,これに伴ってインデクスページにキーが追加されます。このとき,インデクスページ内の未使用領域の比率が小さいと,インデクスページスプリットが頻繁に発生することがあります。インデクスページスプリットが頻繁に発生すると,インデクスの構造の変更に伴うログ量が増加します。
インデクスページスプリットの発生回数を削減するには,統計解析ユティリティ(pdsteditコマンド)で取得したインデクスページスプリットの情報を基に,インデクスページ内の未使用領域の比率を変更します。インデクスページ内の未使用領域の比率を変更するには,定義系SQLのCREATE INDEXのPCTFREEオペランドの値を変更して,インデクスを再度定義します。
統計解析ユティリティで取得したインデクスページスプリットの情報への対処の仕方については,「22.7 インデクスのチューニング」を参照してください。
通常のインデクスページスプリットでは,連続したキー値を追加すると,インデクスページのデータ格納効率が下がります。このような場合,アンバランスインデスクススプリットを使用します。アンバランスインデクススプリットとは,インデクスページのインデクス情報を均等に2分割しないで,不均等に分割することです。これによって,連続したキー値を追加したときに,データの格納効率を向上できます。
アンバランスインデクススプリットが指定された場合,インデクスページのインデクス情報を分割する比率は,キー値の追加位置で決定します。
追加位置がインデクスページから見て前半部分であれば,以降,前半部分にキーが追加されると予測します。このため,追加するキー値より一つ大きいキー値を分割位置として,前半部分を左側ページに格納します。
追加位置が後半部分であれば,以降,後半部分にキーが追加されると予測します。このため,追加位置を分割位置として,後半部分を右側ページに格納します。インデクスページの後半部分にキーを追加した場合のアンバランスインデクススプリットの例を次の図に示します。
図14-3 アンバランスインデクススプリットの例
アンバランスインデクススプリットは,最終ページでないリーフページだけに適用します。また,ロールバック時は,アンバランスインデクススプリットを適用しないで,通常のインデクスページスプリットを実施します。この場合,50:50の割合でページ分割します。
また,リーフページの最終ページは,定義系SQLのCREATE INDEXのPCTFREEオペランドで指定した値に従ってデータを分割します。これは,データロードなどによるキー値の昇順追加に対応するためです。
次に示す条件を満たすインデクスに,アンバランスインデクススプリットを適用すると効果があります。
アンバランスインデクススプリットを使用する場合,定義系SQLのCREATE INDEX,又はCREATE TABLEのインデクスオプションにUNBALANCED SPLITを指定します。
All Rights Reserved. Copyright (C) 2006, 2016, Hitachi, Ltd.