Heim >Datenbank >MySQL-Tutorial >Warum kann ich CURRENT_DATE nicht als Standardwert für eine MySQL-DATE-Spalte festlegen?
CURRENT_DATE-Standardwert-Rätsel
In MySQL kann der Versuch, den Standardwert für eine DATE-Spalte auf CURDATE() oder CURRENT_DATE festzulegen, wie folgt aussehen eine intuitive Wahl. Der Versuch, eine solche Tabelle zu erstellen, schlägt jedoch fehl. In dieser Frage wird erläutert, warum dieses Verhalten auftritt.
Der Schuldige liegt in den Einschränkungen der DEFAULT-Klausel von MySQL. Wie in der offiziellen Dokumentation erklärt:
„Die DEFAULT-Klausel gibt einen Standardwert für eine Spalte an. Mit einer Ausnahme muss der Standardwert eine Konstante sein; er darf keine Funktion oder ein Ausdruck sein.“
Daher wird die Zuweisung von CURRENT_DATE, einer Funktion, die das aktuelle Datum abruft, als Standard für eine DATE-Spalte nicht unterstützt.
Die Ausnahme
Die Ausnahme von dieser Regel ist der Spaltentyp CURRENT_TIMESTAMP. Für eine TIMESTAMP-Spalte können Sie CURRENT_TIMESTAMP als Standardwert angeben, um die Spalte automatisch mit dem aktuellen Datum und der aktuellen Uhrzeit zu füllen.
Problemumgehung
Wenn Sie das beibehalten möchten Wenn Sie das aktuelle Datum und die aktuelle Uhrzeit in einer DATE-Spalte angeben, können Sie einen Trigger verwenden, um das Feld bei Einfüge- und Aktualisierungsvorgängen automatisch zu aktualisieren.
Das obige ist der detaillierte Inhalt vonWarum kann ich CURRENT_DATE nicht als Standardwert für eine MySQL-DATE-Spalte festlegen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!