Update: Nicht optimalen Ausführungsplan auf eine indirekte UPDATE zu einer indizierten Sicht

Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.

286234
Dieser Artikel wurde archiviert. Er wird im vorliegenden Zustand bereitgestellt und nicht mehr aktualisiert.
# FEHLER: 236137 (SHILOH_BUGS)
Problembeschreibung
Ein Update für eine Tabelle zugrunde liegenden eine indizierte Sicht kann in einem nicht optimalen Plan führen, wenn die indizierte Ansicht Aggregatfunktionen enthält.
Ursache
Falsche Zeile schätzt Ergebnis in ein Indexscan statt eines Index seek beim Berechnen des aggregierten Informationen.
Lösung
Beziehen Sie das neueste Service Pack für SQL Server 2000, um dieses Problem zu beheben. Weitere Informationen finden Sie die folgende KB-Artikelnummer:
290211Info: Wie Sie das neueste SQL Server 2000 Service Pack erhalten
Abhilfe
Vermeiden Sie Verwendung von Aggregatfunktionen in einer indizierten Sicht.
Status
Microsoft hat bestätigt, dass dies ein Problem in SQL Server 2000 ist. Dieses Problem wurde erstmals im SQL Server 2000 Service Pack 1.
Weitere Informationen
Führen Sie den folgenden Code um das Problem anzuzeigen. Beachten Sie, dass "Compute skalaren" Schritt eine Index-Suche durchführt.
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				
IV Leistung langsam schnell Geschwindigkeit Optimierung Plan Abfrageoptimierer

Warnung: Dieser Artikel wurde automatisch übersetzt

Eigenschaften

Artikelnummer: 286234 – Letzte Überarbeitung: 01/16/2015 21:28:02 – Revision: 3.2

  • Microsoft SQL Server 2000 Standard Edition
  • kbnosurvey kbarchive kbmt kbbug kbfix kbsqlserv2000sp1fix KB286234 KbMtde
Feedback