PRB: SET CONCAT_NULL_YIELDS_NULL verursachen gespeicherten Prozeduren zu kompilieren

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 294942 - Produkte anzeigen, auf die sich dieser Artikel bezieht
Alles erweitern | Alles schließen

Problembeschreibung

Wenn eine gespeicherte Prozedur die Anweisung SET CONCAT_NULL_YIELDS_NULL enthält und die Anweisung die aktuelle Einstellung von CONCAT_NULL_YIELDS_NULL ändert, wird die Prozedur neu kompiliert werden jedes Mal, dass es ausgeführt wird. Dies kann zu Leistungsproblemen führen.

Ursache

Neukompilierung ist erforderlich, da die Einstellung von CONCAT_NULL_YIELDS_NULL Änderung das Ergebnis und die Möglichkeit, dass Befehle interpretiert werden. In SQL Server 7.0 und SQL Server 2000 ist CONCAT_NULL_YIELDS_NULL auf ON werden standardmäßig in Übereinstimmung mit ANSI-Standards festgelegt.

CONCAT_NULL_YIELDS_NULL auf OFF festlegen in der Datenbank Ebene führt nicht zu das gewünschte Ergebnis weil ODBC- und OLE DB diese Eigenschaft auf beim Herstellen einer Verbindung festgelegt. (Da dies durch ein bit im Paket Verbindung angegeben ist, nicht SQL Profiler angezeigt, dass diese Eigenschaft festgelegt ist.)

Abhilfe

Legen Sie CONCAT_NULL_YIELDS_NULL nicht innerhalb der gespeicherten Prozedur. Lösung wird empfohlen, die ISNULL-Funktion beim Verketten von Zeichenfolgen zu verwenden.

Z. B. eine Abfrage sollten werden geschrieben wie folgt:
SELECT * FROM mytable WHERE name LIKE 'Xavier ' + ISNULL(@lastname,'') + '%'
				
statt wie folgt:
SELECT * FROM mytable WHERE name LIKE 'Xavier ' + @lastname + '%'
				
zwar nicht empfohlen, eine alternative Lösung wäre die Anweisung SET CONCAT_NULL_YIELDS_NULL vor dem Ausführen der gespeicherten Prozedur.

Weitere Informationen

Aus diesem Artikel Adressen nur ein Grund, die gespeicherten Prozeduren möglicherweise neu kompiliert werden; weitere Informationen finden Sie die Artikelnummer unten klicken, um der Microsoft Knowledge Base:
243586Info: Problembehandlung Neukompilierung von gespeicherten Prozeduren

Eigenschaften

Artikel-ID: 294942 - Geändert am: Donnerstag, 16. Oktober 2003 - Version: 3.2
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft SQL Server 2000 Standard Edition
  • Microsoft SQL Server 7.0 Standard Edition
Keywords: 
kbmt kbprb KB294942 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: 294942
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