SET NOCOUNT ON in SQL Server: Kompromisse
Ob „SET NOCOUNT ON“ in SQL Server verwendet werden soll, war schon immer ein Diskussionsthema unter Entwicklern. Einige sehen darin einen Leistungsvorteil, während andere vor möglichen Nachteilen warnen.
Hintergrundwissen
Der Befehl „SET NOCOUNT ON“ unterdrückt die Meldung „Anzahl der betroffenen Zeilen xx Zeilen“, die nach einem DML-Vorgang angezeigt wird. Bei dieser Nachricht handelt es sich um eine Ergebnismenge, die der Client verarbeiten muss, was einen trivialen, aber messbaren Mehraufwand verursacht. In Szenarien mit Triggern oder gespeicherten Prozeduren können mehrere „Zeilen betroffen xx Zeilen“-Meldungen bei einigen ORMs, einschließlich MS Access und JPA, Fehler verursachen.
Unterstützer von SET NOCOUNT ON
Konventionelle Weisheit besagt, dass „SET NOCOUNT ON“ verwendet werden sollte, um die Leistung zu verbessern. Das Argument ist, dass die Meldung „Anzahl der betroffenen Zeilen xx Zeilen“ für die meisten Anwendungen unnötig ist und ihre Unterdrückung den Netzwerkverkehr und die Verarbeitungszeit reduzieren kann. Darüber hinaus wird davon ausgegangen, dass SET NOCOUNT ON Fehler in bestimmten Szenarios verhindert, in denen der Client eine bestimmte Anzahl von Zeilen erwartet.
Gegner von SET NOCOUNT ON
Gegner von „SET NOCOUNT ON“ argumentieren, dass es erweiterte Datenbankoperationen behindern könnte. Das Unterdrücken von Informationen zur Zeilenanzahl kann beispielsweise Folgendes beeinträchtigen:
- Verwenden Sie IF EXISTS, um doppelte Datensätze zu vermeiden
- Verwenden Sie WHERE NOT EXISTS, um die Ergebnisse einzuschränken
- Belanglose Aktualisierungen herausfiltern
- Tabellenzugriff vor oder nach DML-Vorgängen durchführen
Darüber hinaus kann SET NOCOUNT ON bei einigen Client-Frameworks (z. B. SqlDataAdapter und JPA von ADO.NET) zu unerwartetem Verhalten führen. Diese Frameworks erwarten Informationen zur Zeilenanzahl, und deren Fehlen kann zu Fehlern oder falschen Ergebnissen führen.
Auswirkungen auf die Leistung
Während allgemein angenommen wird, dass SET NOCOUNT ON die Leistung verbessert, deuten die Daten auf etwas anderes hin. Im TDS-Protokoll spart SET NOCOUNT ON nur 9 Bytes pro Abfrage, während der Befehl selbst 14 Bytes umfasst. Bei der Meldung „Anzahl der betroffenen Zeilen xx Zeilen“ handelt es sich nicht um ein separates Netzwerkpaket, sondern um eine kleine eingebettete Struktur. Daher ist die Leistungsverbesserung minimal.
Fazit
Ob „SET NOCOUNT ON“ verwendet werden soll oder nicht, hängt von den spezifischen Bedürfnissen und Überlegungen ab. Dies kann in Szenarien von Vorteil sein, in denen die Leistung von entscheidender Bedeutung ist oder in denen das Client-Framework nicht auf Informationen zur Zeilenanzahl angewiesen ist. Bevor Sie SET NOCOUNT ON global implementieren, sollten Sie jedoch unbedingt die möglichen Nachteile berücksichtigen.
Das obige ist der detaillierte Inhalt vonSollten Sie SET NOCOUNT ON in SQL Server verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

MysqloffersVariousStorageEngines, EverySuitedfordifferentusecases: 1) InnoDbisidealforApplicationsNeedingaCidComplianceandHighConcurrency, SupportingingTransactions und MisseractersactionSactions.2) MyisamisBestforread-Heavyworks, Fehlen von Abladungen, mangelndtransaktionen

Zu den allgemeinen Sicherheitslücken in MySQL gehören die SQL -Injektion, schwache Passwörter, unsachgemäße Berechtigungskonfiguration und eine nicht updierte Software. 1. SQL -Injektion kann durch Verwendung von Vorverarbeitungsanweisungen verhindert werden. 2. Schwache Passwörter können vermieden werden, indem Sie starke Kennwortstrategien verwenden. 3. Eine unsachgemäße Berechtigungskonfiguration kann durch regelmäßige Überprüfung und Anpassung der Benutzerberechtigungen behoben werden. 4. Die nicht updierte Software kann durch regelmäßiges Überprüfen und Aktualisieren der MySQL -Version gepatcht werden.

Das Identifizieren langsamer Abfragen in MySQL kann erreicht werden, indem langsame Abfrageprotokolle aktiviert und Schwellenwerte festgelegt werden. 1. Aktivieren Sie langsame Abfrageprotokolle und setzen Sie Schwellenwerte. 2. Sehen und analysieren Sie langsame Abfrageprotokolldateien und verwenden Sie Tools wie MySQLDUMPSLOW oder PT-Query-Digest für eingehende Analysen. 3. Die Optimierung langsamer Abfragen kann durch Indexoptimierung, Umschreiben von Abfragen und Vermeidung der Verwendung von Select*erreicht werden.

Um die Gesundheit und Leistung von MySQL -Servern zu überwachen, sollten Sie auf Systemgesundheit, Leistungsmetriken und Abfrageausführung achten. 1) Überwachen Sie die Systemgesundheit: Verwenden Sie die Befehle von Top-, HTOP- oder ShowglobalStatus, um CPU-, Speicher-, Festplatten -E/A- und Netzwerkaktivitäten anzuzeigen. 2) Leistungsindikatoren verfolgen: Überwachen Sie die Schlüsselindikatoren wie die Abfragennummer pro Sekunde, die durchschnittliche Abfragezeit und den Cache -Hit -Rate. 3) Optimierung der Abfrageausführung sicherstellen: Aktivieren Sie langsame Abfragenprotokolle, zeichnen und optimieren Sie Abfragen, deren Ausführungszeit den festgelegten Schwellenwert überschreitet.

Der Hauptunterschied zwischen MySQL und Mariadb ist Leistung, Funktionalität und Lizenz: 1. MySQL wird von Oracle entwickelt und Mariadb ist seine Gabel. 2. Mariadb kann in Umgebungen mit hoher Last besser abschneiden. 3.MariADB bietet mehr Speichermotoren und Funktionen. 4.Mysql nimmt eine doppelte Lizenz an, und Mariadb ist vollständig Open Source. Die vorhandene Infrastruktur, Leistungsanforderungen, funktionale Anforderungen und Lizenzkosten sollten bei der Auswahl berücksichtigt werden.

MySQL verwendet eine GPL -Lizenz. 1) Die GPL -Lizenz ermöglicht die freie Verwendung, Änderung und Verteilung von MySQL, aber die geänderte Verteilung muss GPL entsprechen. 2) Gewerbelizenzen können öffentliche Änderungen vermeiden und für gewerbliche Anwendungen geeignet sind, die Vertraulichkeit erfordern.

Die Situationen bei der Auswahl von InnoDB anstelle von MyISAM umfassen: 1) Unterstützung der Transaktion, 2) hohe Genauigkeitsumgebung, 3) hohe Datenkonsistenz; Umgekehrt umfasst die Situation bei der Auswahl von MyISAM: 1) hauptsächlich Lesen von Operationen, 2) Es ist keine Transaktionsunterstützung erforderlich. InnoDB ist für Anwendungen geeignet, die eine hohe Datenkonsistenz und Transaktionsverarbeitung erfordern, z. B. E-Commerce-Plattformen, während MyISAM für lessintensive und transaktionsfreie Anwendungen wie Blog-Systeme geeignet ist.

In MySQL besteht die Funktion von Fremdschlüssel darin, die Beziehung zwischen Tabellen herzustellen und die Konsistenz und Integrität der Daten zu gewährleisten. Fremdeschlüssel behalten die Wirksamkeit von Daten durch Referenzintegritätsprüfungen und Kaskadierungsvorgänge bei. Achten Sie auf die Leistungsoptimierung und vermeiden Sie bei der Verwendung häufige Fehler.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung

MantisBT
Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool
