Bei der Arbeit mit älteren MySQL-Datenbanken kommt es nicht selten zu Problemen aufgrund von Zeichenänderungen Sets und MySQL-Versionen. Dieses spezielle Problem betrifft die Änderung des Zeichensatzes einer Datetime-Spalte und das Auftreten einer Fehlermeldung bezüglich eines „falschen Datetime-Werts“.
Problembeschreibung:
Analyse:
Die Hauptursache dieses Problems ist das Vorhandensein ungültiger Datums-/Uhrzeitwerte in der erstellten Spalte, insbesondere des Nullwerts „0000“. -00-00 00:00:00'. MySQL 5.7 hat strengere Validierungsregeln für Datums-/Uhrzeitwerte und dieser ungültige Wert führt dazu, dass die Spaltenänderung fehlschlägt.
Mögliche Lösungen:
1. Identifizieren und Aktualisieren von Nullwerten:
Bevor Sie den Zeichensatz der erstellten Spalte ändern, ist es wichtig, alle Nullwerte zu identifizieren und auf ein gültiges Datum/Uhrzeitdatum zu aktualisieren. Dies kann mit der folgenden Abfrage erfolgen:
UPDATE users SET created = NULL WHERE created IS NULL;
2. Konvertieren ungültiger Datetime-Werte in Null:
Wenn in der erstellten Spalte keine Nullwerte vorhanden sind, muss der ungültige Datetime-Wert „0000-00-00 00:00:00“ in Null konvertiert werden. Dies kann mit der folgenden Abfrage erreicht werden:
UPDATE users SET created = NULL WHERE CAST(created AS CHAR(20)) = '0000-00-00 00:00:00';
3. Ändern des Spaltenzeichensatzes:
Sobald die ungültigen Datums-/Uhrzeitwerte aufgelöst sind, ist es jetzt sicher, den Zeichensatz der Spalte „Vorname“ zu ändern:
ALTER TABLE users MODIFY first_name varchar(45) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL;
4 . Zusätzliche Überlegungen:
Das obige ist der detaillierte Inhalt vonWarum führt die Änderung des Zeichensatzes der MySQL-Tabellenspalte zu Fehlern vom Typ „Falscher Datum/Uhrzeit-Wert'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!