[FIX] インデックス付きビューで最適な実行プランが選択されない

この記事は、以前は次の ID で公開されていました: JP286234
この資料は、アーカイブされました。これは "現状のまま" で提供され、更新されることはありません。
現象
インデックス付きビューが集計関数を含んでいる場合、インデックス付きビューの元になるテーブルを更新すると最適なプランにならないことがあります。
原因
集計情報を計算するときの行の見積もりが誤っていると、インデックスの検索ではなくインデックスのスキャンが実行されます。
解決方法
この問題を解決するために、SQL Server 2000 の最新の Service Pack の適用をお願いいたします。
最新の SQL Server サービスパックのダウンロードおよびインストールについて詳しくは以下をご覧下さい。

http://www.microsoft.com/japan/sql/download/default.asp (日本語版)
http://www.microsoft.com/sql/downloads/default.htm(英語版)
回避策
インデックス付きビューで集計関数の使用を避けます。
状況
弊社では、これを Microsoft SQL Server version 2000 の問題として確認しています。
この問題は、Microsoft SQL Server version 2000 Service Pack 1 で修正されています。
詳細
次のコードを実行すると、問題が発生します。"compute scalar" の手順でインデックスの検索を実行していることに注意してください。
use tempdbgoIF EXISTS(SELECT * FROM information_schema.views where table_name = 'v1')  drop view v1IF EXISTS(SELECT * FROM information_schema.tables where table_name = 't1')  drop table t1gocreate table t1 (a int, b bigint NOT NULL)set nocount ondeclare @i intset @i=1while (@i<100000)begin  insert into t1 values (@i,0)  set @i=@i+1endgoSET NUMERIC_ROUNDABORT OFF SET ANSI_PADDING,ANSI_WARNINGS,CONCAT_NULL_YIELDS_NULL,ARITHABORT,QUOTED_IDENTIFIER,ANSI_NULLS ONGOcreate view v1 (a,b,c) with schemabinding as select a, sum(b), count_big(*) from dbo.t1 group by a gocreate unique clustered index i1 on v1(a)goset statistics profile oninsert into t1 values (1,1)set statistics profile offgo
関連情報
この資料は米国 Microsoft Corporation から提供されている Knowledge Base の Article ID 286234 (最終更新日 2001-06-13) をもとに作成したものです。

iv performance slow fast speed optimization query plan optimizer
プロパティ

文書番号:286234 - 最終更新日: 01/16/2015 21:28:10 - リビジョン: 2.1

Microsoft SQL Server 2000 Standard Edition

  • kbnosurvey kbarchive kbbug kbfix kbsqlserv2000bug kbsqlserv2000sp1fix KB286234
フィードバック