Globalen sql_mode in MySQL festlegen
In MySQL definiert sql_mode das Standardverhalten des Datenbankservers. Wenn Sie sql_mode global festlegen, wird der konfigurierte Modus auf alle nachfolgenden Verbindungen und Sitzungen angewendet. Dies unterscheidet sich vom Festlegen von sql_mode pro Sitzung, das sich nur auf die aktuelle Verbindung auswirkt.
Wenn beim globalen Festlegen von sql_mode Fehler auftreten, ist es wichtig, die Syntax zu überprüfen. Der richtige Weg, mehrere Modi in einem globalen Kontext festzulegen, ist:
SET GLOBAL sql_mode = 'NO_BACKSLASH_ESCAPES', 'STRICT_TRANS_TABLE', 'NO_AUTO_CREATE_USER', 'NO_ENGINE_SUBSTITUTION'
Vorteile des globalen Modus und des Sitzungsmodus
Global Modi:
Sitzungsmodi:
Bevorzugte Einstellung
Die bevorzugte Einstellung hängt von der Anwendung und der Umgebung ab. Wenn ein einheitliches Verhalten auf der ganzen Linie gewünscht ist, empfiehlt sich die globale Einstellung von sql_mode. Wenn jedoch bestimmte Sitzungsanforderungen auftreten, bieten Sitzungsmodi die nötige Flexibilität.
Globalen sql_mode dauerhaft festlegen
Um globale sql_mode-Änderungen dauerhaft zu machen, müssen sie konfiguriert werden die MySQL-Konfigurationsdatei (z. B. /etc/mysql/my.cnf unter Linux). Fügen Sie im Abschnitt [mysqld] die Option sql_mode hinzu oder ändern Sie sie. Zum Beispiel:
[mysqld] sql_mode = NO_BACKSLASH_ESCAPES, STRICT_TRANS_TABLES, NO_ENGINE_SUBSTITUTION
Für neuere Versionen von MySQL (z. B. 5.7.8 oder höher) erfordert die sql_mode-Einstellung möglicherweise einen Bindestrich anstelle eines Unterstrichs und doppelter Anführungszeichen:
[mysqld] sql-mode="STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION"
Konsultieren Sie immer die MySQL-Dokumentation für die entsprechende Syntax basierend auf der verwendeten MySQL-Version.
Das obige ist der detaillierte Inhalt vonWie stelle und verwalte ich den globalen „sql_mode' in MySQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!