ホームページ > データベース > mysql チュートリアル > SQL Server 2012 の ID 列で散発的な増分ジャンプが発生するのはなぜですか?

SQL Server 2012 の ID 列で散発的な増分ジャンプが発生するのはなぜですか?

Mary-Kate Olsen
リリース: 2025-01-18 02:42:13
オリジナル
938 人が閲覧しました

Why Do SQL Server 2012 Identity Columns Exhibit Sporadic Increment Jumps?

SQL Server 2012 自動インクリメント列の例外的なインクリメント ジャンプ

SQL Server 2012 では、自動インクリメントされる int 列で予期しない動作が発生する可能性があります。つまり、増分が小さい値から大きい値にジャンプします。

質問:

ID 列の増分が断続的にジャンプし、シーケンス内の値がスキップされるのはなぜですか?

答え:

この動作は、SQL Server 2012 でのシーケンスの導入後の ID キー生成の変更が原因で発生します。 ID 値は、バックグラウンドでシーケンス オブジェクトを使用して生成されるようになりました。これらの値はパフォーマンスを向上させるためにキャッシュされるため、デルタ シーケンスにギャップが生じる場合があります。

緩和計画:

以前の増分動作に戻すには:

  • トレース フラグ 272 を有効にする: これにより、生成された各 ID 値のログが生成されますが、パフォーマンスに影響を与える可能性があります。
  • NO CACHE 設定でシーケンス ジェネレーターを作成します。これにより、キャッシュが無効になり、一貫したデルタ シーケンスが保証されます。新しいシーケンスを使用して既存の ID 列を再作成してください。

以上がSQL Server 2012 の ID 列で散発的な増分ジャンプが発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート