Heim >häufiges Problem >Was sind die Alter-Befehle in MySQL?

Was sind die Alter-Befehle in MySQL?

小老鼠
小老鼠Original
2023-12-14 10:38:251634Durchsuche

alter-Befehle umfassen das Hinzufügen von Spalten, das Löschen von Spalten, das Ändern von Spaltennamen, das Ändern von Spaltendatentypen, das Festlegen von Standardwerten, das Entfernen von Standardwerten, das Hinzufügen von Primärschlüsseln, das Löschen von Primärschlüsseln, das Hinzufügen von Indizes, das Löschen von Indizes, das Hinzufügen eindeutiger Einschränkungen, das Löschen eindeutiger Einschränkungen, Fremdschlüsseleinschränkungen hinzufügen, Fremdschlüsseleinschränkungen löschen, den Namen der Tabelle ändern usw. Detaillierte Einführung: 1. Spalten hinzufügen: ALTER TABLE Tabellenname ADD Spaltenname Datentyp; 2. Spalten löschen usw.

Was sind die Alter-Befehle in MySQL?

Der ALTER-Befehl in MySQL wird verwendet, um die Struktur einer vorhandenen Datenbanktabelle zu ändern. Im Folgenden sind einige häufige Verwendungszwecke und Beispiele des ALTER-Befehls aufgeführt:

sql

ALTER TABLE table_name ADD column_name data_type;

2. Löschen Sie eine Spalte:

sql

ALTER TABLE table_name DROP COLUMN column_name;

3. Ändern Sie den Spaltennamen:

sql

ALTER TABLE table_name CHANGE old_column_name new_column_name data_type;

4. Spaltendatentyp ändern:

sql

ALTER TABLE table_name MODIFY COLUMN column_name new_data_type;

6. Standardwert entfernen:

sql

ALTER TABLE table_name ALTER COLUMN column_name SET DEFAULT 'default_value';

sql

ALTER TABLE table_name ALTER COLUMN column_name DROP DEFAULT;

8. Primärschlüssel löschen:

sql

ALTER TABLE table_name ADD PRIMARY KEY (column_name);

10. Index löschen:

sql

ALTER TABLE table_name DROP PRIMARY KEY;

ALTER TABLE table_name ADD INDEX index_name (column_name);

12. Löschen eindeutige Einschränkung:

sql

ALTER TABLE table_name DROP INDEX index_name;

– Löschen Sie den entsprechenden Index. Beachten Sie jedoch, dass nicht alle eindeutigen Einschränkungen einen Index generieren. Sie müssen daher den Indexnamen ermitteln, der der eindeutigen Einschränkung entspricht, die Sie wirklich löschen müssen.

13. Fremdschlüsseleinschränkungen hinzufügen:

Fügen Sie beispielsweise eine Fremdschlüsseleinschränkung zur Auftragstabelle zur Kundentabelle hinzu:

sql

ALTER TABLE table_name ADD UNIQUE (column_name);

14. Löschen Sie Fremdschlüsseleinschränkungen: (Hinweis: MySQL stellt die nicht direkt bereit Möglichkeit zum Löschen von Fremdschlüsseleinschränkungen (Befehl, aber Sie können dies auch indirekt tun, indem Sie die Spalte des Fremdschlüssels löschen):

Löschen Sie beispielsweise die Spalte customer_id in der Auftragstabelle:

sql

ALTER TABLE table_name DROP INDEX column_name;

-- Beachten Sie, dass dies der Fall ist Löschen Sie die gesamte Spalte, nicht nur die Fremdschlüsseleinschränkung. Stellen Sie sicher, dass dies das ist, was Sie wollen. Wenn Sie nur die Fremdschlüsseleinschränkung löschen, aber die Spalte behalten möchten, müssen Sie die ursprüngliche SQL-Anweisung finden, die die Fremdschlüsseleinschränkung erstellt hat, und sie manuell löschen. Dies ist normalerweise in den Metadaten oder Protokollen der Datenbank zu finden.

15. Ändern Sie den Namen der Tabelle: (Hinweis: MySQL stellt den Befehl zum Umbenennen der Tabelle nicht direkt bereit, Sie können dies jedoch indirekt erreichen, indem Sie die Tabelle kopieren und die alte Tabelle löschen):

Kopieren Sie zunächst die Tabelle Struktur und Daten in eine neue Tabelle:

SQL

ALTER TABLE orders ADD FOREIGN KEY (customer_id) REFERENCES customer(id);

Das obige ist der detaillierte Inhalt vonWas sind die Alter-Befehle in MySQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn