Update: der Abfrageplan für eine gespeicherte Prozedur ist nicht zwischengespeichert werden, wenn die gespeicherte Prozedur eine BLOB-Variable verwendet und die Variable wird in einer Zeichenfolgenfunktion in Microsoft SQL Server 2008 verwendet

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 2380435 - Produkte anzeigen, auf die sich dieser Artikel bezieht
Microsoft stellt Updates für Microsoft SQL Server 2008, als downloadbare Datei. Da die Updates kumulativ sind, enthält jede neue Version alle Hotfixes und alle, die Sicherheitsupdates in den vorherigen enthalten waren, SQL Server 2008 beheben Version.
Alles erweitern | Alles schließen

Auf dieser Seite

Problembeschreibung

Folgendes Szenario:
  • Erstellen Sie eine gespeicherte Prozedur im Microsoft SQL Server 2008.
  • Die gespeicherte Prozedur verwendet eine Variable binary large Object (BLOB).
  • Der BLOB-Variable wird verwendet, in einer String-Funktion.
  • Ausführen der gespeicherten Prozedur.
Der Abfrageplan für die gespeicherte Prozedur wird in diesem Szenario nicht zwischengespeichert.

Lösung

SQL Server 2008 Servicepack 1

Die Fehlerbehebung für dieses Problem wurde zuerst im kumulativen Update 10 für SQL Server 2008 Service Pack 1 veröffentlicht. Weitere Informationen zu diesem kumulativen Updatepaket, klicken Sie auf die folgende KB-Artikelnummer:
2279604Kumulative Updatepaket 10 für SQL Server 2008 Service Pack 1
Hinweis:Da die Builds kumulativ, jedem neuen Update-Version enthält alle Hotfixes und Release beheben Sie alle Sicherheitsupdates, die mit früheren SQL Server 2008 geliefert wurden. Microsoft empfiehlt, dass Sie sollten anwenden, die neueste Version der Updates, die diesen Hotfix enthält. Für Weitere Informationen klicken Sie auf die folgende KB-Artikelnummer:
970365Die SQL Server 2008 erstellt, die nach der Veröffentlichung von SQL Server 2008 Service Pack 1 wurde veröffentlicht wurden
Microsoft SQL Server 2008-Hotfixes sind für bestimmte SQL Server Servicepacks erstellt. Sie müssen einen Hotfix für SQL Server 2008 Service Pack 1 auf eine Installation von SQL Server 2008 Service Pack 1 anwenden. In der Standardeinstellung ist jeder Hotfix, der in einem SQL Server Servicepack zur Verfügung gestellt wird im nächsten Servicepack für SQL Server enthalten.

Status

Microsoft hat bestätigt, dass es ein Problem bei den Microsoft-Produkten, die in der im Abschnitt "Beziehen sich auf" aufgelisteten handelt

Weitere Informationen

, Um dieses Problem zu reproduzieren, gehen Sie folgendermaßen vor:
  1. Führen Sie den folgenden Code zum Erstellen von zwei gespeicherter Prozeduren ("p_test1" und "p_test2"). "P_test1" verwendet eine BLOB-Variable und "p_test2" verwendet eine Variable vom Datentyp nvarchar(100).
    use tempdb
    go
    if OBJECT_ID('p_test1') is not null drop proc p_test1
    if OBJECT_ID('p_test2') is not null drop proc p_test2
    go
    create proc p_test1
    @s nvarchar(max)
    as
    begin
    select * from sys.objects 
    where name = UPPER(@s)
    end
    go
    create proc p_test2
    @s nvarchar(100)
    as
    begin
    select * from sys.objects 
    where name = UPPER(@s)
    end
    go
    
  2. Führen Sie den folgenden Code den Prozedur-Cache zu löschen, und führen Sie die beiden gespeicherten Prozeduren:
    dbcc freeproccache
    go
    exec p_test1 N'abc'
    exec p_test2 N'abc'
    go
    
  3. Führen Sie den folgenden Code zum Überprüfen von zwischengespeicherten Plans:
    select object_name(CONVERT(int, a.value)), cp.*
    from sys.dm_exec_cached_plans cp
    cross apply sys.dm_exec_plan_attributes(cp.plan_handle) a
    where cp.objtype = 'Proc'
    and a.attribute = 'objectid'
    
    
Hinweis:Wenn viele gleichzeitige Ausführungen der diese Art von gespeicherter Prozedur, die auf einer Instanz von Microsoft SQL Server 2008, treten möglicherweise blockiert, die durch Kompilieren der Sperren für die Instanz verursacht wird.

Finden Sie weitere Informationen über die Beschreibung des SQL Server blockieren verursacht durch Kompilieren sperren, unter im folgenden Artikel der Microsoft Knowledge Base:
263889Beschreibung von SQL Server zu blockieren, verursacht durch Kompilieren Sperren

Informationsquellen

Finden Sie weitere Informationen über die String-Funktionen (Transact-SQL) auf den folgenden Microsoft-Website:
Zeichenfolgenfunktionen (Transact-SQL)
Weitere Informationen zu den inkrementellen Dienstmodell für SQL Server, klicken Sie auf die folgende KB-Artikelnummer:
935897Ein inkrementelles Dienstmodell ist verfügbar in der SQL Server-Team zum Übermitteln von Hotfixes für gemeldete Probleme
Finden Sie weitere Informationen über das Namensschema für SQL Server-Updates die folgende KB-Artikelnummer:
822499Neues Benennungsschema für Microsoft SQL Server-Software-Updatepaketen
Weitere Informationen zur Terminologie für Softwareupdates, klicken Sie auf die folgende KB-Artikelnummer:
824684Beschreibung der Standardterminologie, die zum Beschreiben von Microsoft-Softwareupdates verwendet wird

Eigenschaften

Artikel-ID: 2380435 - Geändert am: Dienstag, 21. September 2010 - Version: 1.0
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Standard Edition for Small Business
  • Microsoft SQL Server 2008 Workgroup
Keywords: 
kbqfe kbfix kbsurveynew kbexpertiseadvanced kbmt KB2380435 KbMtde
Maschinell übersetzter Artikel
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.
Den englischen Originalartikel können Sie über folgenden Link abrufen: 2380435
Microsoft stellt Ihnen die in der Knowledge Base angebotenen Artikel und Informationen als Service-Leistung zur Verfügung. Microsoft übernimmt keinerlei Gewährleistung dafür, dass die angebotenen Artikel und Informationen auch in Ihrer Einsatzumgebung die erwünschten Ergebnisse erzielen. Die Entscheidung darüber, ob und in welcher Form Sie die angebotenen Artikel und Informationen nutzen, liegt daher allein bei Ihnen. Mit Ausnahme der gesetzlichen Haftung für Vorsatz ist jede Haftung von Microsoft im Zusammenhang mit Ihrer Nutzung dieser Artikel oder Informationen ausgeschlossen.

Ihr Feedback an uns

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com