Heim > Datenbank > Oracle > So ändern Sie die Tabellenstruktur in Oracle

So ändern Sie die Tabellenstruktur in Oracle

青灯夜游
Freigeben: 2022-01-13 11:37:52
Original
10433 Leute haben es durchsucht

In Oracle können Sie die Anweisung „ALTER TABLE“ verwenden, um die Struktur der ursprünglichen Tabelle zu ändern, indem Sie Spalten hinzufügen oder löschen, den ursprünglichen Spaltentyp ändern, Spalten oder Tabellen umbenennen usw. Syntax „ALTER TABLE Tabellenname [Optionen ändern]“. ALTER TABLE Tabellenname [Optionen ändern]

So ändern Sie die Tabellenstruktur in Oracle

Die Betriebsumgebung dieses Tutorials: Windows 7-System, Oracle 11g-Version, Dell G3-Computer.

In Oracle können Sie die Anweisung „ALTER TABLE“ verwenden, um die Tabellenstruktur zu ändern. ALTER TABLE”语句来修改表结构。

ALTER TABLE 语句可以改变原有表的结构,例如增加或删减列、更改原有列类型、重新命名列或表等。

ALTER TABLE 语句的语法:

ALTER TABLE 表名 [修改选项]
Nach dem Login kopieren

在上面的语句中,

  • 首先,指定要修改的表名称。

  • 其次,指出想在表名称后执行的修改操作。

ALTER TABLE语句可用来:

  • 添加一个或多个列
  • 修改列定义
  • 删除一列或多列
  • 重命名列
  • 重命名表

下面来看看一些例子来了解每个操作的工作原理。

Oracle ALTER TABLE示例

我们将使用在上一个教程中创建的persons表进行演示。

-- 12c语法
CREATE TABLE persons(
    person_id NUMBER GENERATED BY DEFAULT AS IDENTITY,
    first_name VARCHAR2(50) NOT NULL,
    last_name VARCHAR2(50) NOT NULL,
    PRIMARY KEY(person_id)
);
Nach dem Login kopieren

1. 添加列的例子

要将新列添加到表中,请使用以下语法:

ALTER TABLE table_name
ADD column_name type constraint;
Nach dem Login kopieren

例如,以下语句将一个名为birthdate的新列添加到persons表中:

ALTER TABLE persons 
ADD birthdate DATE NOT NULL;
Nach dem Login kopieren

如果查看persons表格,会看到birthdate日期列被添加到列列表的末尾:

DESC persons; 

Name       Null     Type         
---------- -------- ------------ 
PERSON_ID  NOT NULL NUMBER       
FIRST_NAME NOT NULL VARCHAR2(50) 
LAST_NAME  NOT NULL VARCHAR2(50) 
BIRTHDATE  NOT NULL DATE
Nach dem Login kopieren

要同时向表中添加多列,请按如下所示将新列置于括号内:

ALTER TABLE table_name
ADD (
    column_name type constraint,
    column_name type constraint,
    ...
);
Nach dem Login kopieren

看下面的例子:

ALTER TABLE persons 
ADD (
    phone VARCHAR(20),
    email VARCHAR(100)
);
Nach dem Login kopieren

在这个例子中,语句在users表中添加了两个名为phoneemail的新列。

DESC persons

Name       Null     Type          
---------- -------- ------------- 
PERSON_ID  NOT NULL NUMBER        
FIRST_NAME NOT NULL VARCHAR2(50)  
LAST_NAME  NOT NULL VARCHAR2(50)  
BIRTHDATE  NOT NULL DATE          
PHONE               VARCHAR2(20)  
EMAIL               VARCHAR2(100)
Nach dem Login kopieren

2. 修改列的属性的示例

要修改列的属性,请使用以下语法:

ALTER TABLE table_name
  MODIFY column_name type constraint;
Nach dem Login kopieren

例如,下面的语句将birthdate列更改为一个空列:

ALTER TABLE persons MODIFY birthdate DATE NULL;
Nach dem Login kopieren

我们再次验证persons表结构:

DESC persons

Name       Null     Type          
---------- -------- ------------- 
PERSON_ID  NOT NULL NUMBER        
FIRST_NAME NOT NULL VARCHAR2(50)  
LAST_NAME  NOT NULL VARCHAR2(50)  
BIRTHDATE           DATE          
PHONE               VARCHAR2(20)  
EMAIL               VARCHAR2(100)
Nach dem Login kopieren

正如所看到的,birthdate日期变得无能为力。

要修改多个列,请使用以下语法:

 ALTER TABLE table_name
  MODIFY ( column_1 type constraint,
          column_1 type constraint,
         ...);
Nach dem Login kopieren

例如,以下语句将phoneemail列更改为NOT NULL列,并将email列的长度扩展为255个字符:

ALTER TABLE persons MODIFY(
    phone VARCHAR2(20) NOT NULL,
    email VARCHAR2(255) NOT NULL
);
Nach dem Login kopieren

再次验证persons表结构:

DESC persons;

Name       Null     Type          
---------- -------- ------------- 
PERSON_ID  NOT NULL NUMBER        
FIRST_NAME NOT NULL VARCHAR2(50)  
LAST_NAME  NOT NULL VARCHAR2(50)  
BIRTHDATE           DATE          
PHONE      NOT NULL VARCHAR2(20)  
EMAIL      NOT NULL VARCHAR2(255)
Nach dem Login kopieren

3. 删除现有的列的示例

要从表中删除现有的列,请使用以下语法:

ALTER TABLE table_name
DROP COLUMN column_name;
Nach dem Login kopieren

该语句从表结构中删除列,并删除存储在该列中的数据。以下示例从persons表中删除birthdate日期类型的列:

ALTER TABLE persons
DROP
  COLUMN birthdate;
Nach dem Login kopieren

再次查看persons表结构,就会发现birthdate列已被删除:

DESC persons;

Name       Null     Type          
---------- -------- ------------- 
PERSON_ID  NOT NULL NUMBER        
FIRST_NAME NOT NULL VARCHAR2(50)  
LAST_NAME  NOT NULL VARCHAR2(50)  
PHONE      NOT NULL VARCHAR2(20)  
EMAIL      NOT NULL VARCHAR2(255)
Nach dem Login kopieren

要同时删除多个列,请使用以下语法:

ALTER TABLE table_name 
DROP (column_1,column_2,...);
Nach dem Login kopieren

例如,以下语句从个人表中删除phoneemail列:

ALTER TABLE persons
DROP
  ( email, phone );
Nach dem Login kopieren

我们再来看一下persons表:

DESC persons;

Name       Null     Type         
---------- -------- ------------ 
PERSON_ID  NOT NULL NUMBER       
FIRST_NAME NOT NULL VARCHAR2(50) 
LAST_NAME  NOT NULL VARCHAR2(50)
Nach dem Login kopieren

emailphone列已按预期删除。

4. 重命名列的示例

从版本9i开始,Oracle添加了一个用于重命名列的子句,如下所示:

ALTER TABLE table_name
RENAME COLUMN column_name TO new_name;
Nach dem Login kopieren

例如,以下语句将first_name列重命名为forename列:

ALTER TABLE persons 
RENAME COLUMN first_name TO forename;
Nach dem Login kopieren

以下语句检查结果:

DESC persons;

Name      Null     Type         
--------- -------- ------------ 
PERSON_ID NOT NULL NUMBER       
FORENAME  NOT NULL VARCHAR2(50) 
LAST_NAME NOT NULL VARCHAR2(50)
Nach dem Login kopieren

5. 重命名表的例子

要将一个表重命名为一个新的name的表名,使用下面的语法:

ALTER TABLE table_name
RENAME TO new_table_name;
Nach dem Login kopieren

例如,下面的语句将users表重命名为people

ALTER TABLE-Anweisung kann die Struktur der ursprünglichen Tabelle ändern, z. B. Spalten hinzufügen oder löschen, den ursprünglichen Spaltentyp ändern, Spalten oder Tabellen umbenennen usw.

Syntax der ALTER TABLE-Anweisung:

ALTER TABLE persons RENAME TO people;
Nach dem Login kopieren
In der obigen Anweisung 🎜
  • 🎜Geben Sie zunächst den Namen der zu ändernden Tabelle an. 🎜
  • 🎜Zweitens geben Sie nach dem Tabellennamen den Änderungsvorgang an, den Sie durchführen möchten. 🎜
🎜ALTER TABLE-Anweisung kann verwendet werden, um: 🎜
  • eine oder mehrere Spalten hinzuzufügen
  • Spaltendefinitionen zu ändern
  • Eine oder mehrere Spalten löschen
  • Spalten umbenennen
  • Tabelle umbenennen
🎜Schauen wir uns einige Beispiele an, um zu verstehen, wie die einzelnen Vorgänge prinzipiell funktionieren. 🎜

Oracle ALTER TABLE-Beispiel

🎜Wir werden es im vorherigen Tutorial verwenden Demonstration mit der Tabelle persons, die in erstellt wurde. 🎜rrreee

🎜1. Beispiel für das Hinzufügen einer Spalte

🎜Um der Tabelle eine neue Spalte hinzuzufügen, verwenden Sie Folgendes Syntax: 🎜rrreee🎜Zum Beispiel fügt die folgende Anweisung eine neue Spalte mit dem Namen Geburtsdatum zur Tabelle Personen hinzu: 🎜rrreee🎜Wenn Sie die Personenanzeigen > table wird die Datumsspalte birthdate am Ende der Spaltenliste hinzugefügt: 🎜rrreee🎜 Um mehrere Spalten gleichzeitig zur Tabelle hinzuzufügen, schließen Sie die neuen Spalten wie folgt in Klammern ein : 🎜rrreee🎜 Schauen Sie sich das folgende Beispiel an: 🎜rrreee🎜 In diesem Beispiel fügt die Anweisung zwei neue Einträge mit den Namen phone und email in den usershinzu > Tabellenliste. 🎜rrreee

🎜2. Beispiel für das Ändern von Spaltenattributen strong>

🎜Um die Eigenschaften einer Spalte zu ändern, verwenden Sie die folgende Syntax: 🎜rrreee🎜Zum Beispiel ändert die folgende Anweisung die Spalte birthdate in eine leere Spalte: 🎜rrreee🎜Wir überprüfen erneut Personen-Tabellenstruktur: 🎜rrreee🎜Wie Sie sehen können, wird das Geburtsdatum-Datum machtlos. 🎜🎜Um mehrere Spalten zu ändern, verwenden Sie die folgende Syntax: 🎜rrreee🎜Zum Beispiel ändert die folgende Anweisung die Spalten phone und email in NOT NULL-Spalte und erweitern Sie die Länge der Spalte email auf 255 Zeichen: 🎜rrreee🎜Überprüfen Sie die Tabellenstruktur persons erneut: 🎜rrreee

🎜3. Beispiel für das Löschen einer vorhandenen Spalte

🎜Um eine vorhandene Spalte aus einer Tabelle zu löschen, verwenden Sie die folgende Syntax :🎜rrreee🎜Diese Anweisung entfernt eine Spalte aus der Tabellenstruktur und löscht die in dieser Spalte gespeicherten Daten. Das folgende Beispiel löscht die Datumstypspalte birthdate aus der Tabelle persons: 🎜rrreee🎜Schauen Sie sich die Tabellenstruktur persons noch einmal an und Sie werden birthdateSpalte wurde gelöscht: 🎜rrreee🎜Um mehrere Spalten gleichzeitig zu löschen, verwenden Sie die folgende Syntax: 🎜rrreee🎜Zum Beispiel löscht die folgende Anweisung phone und emailSpalte: 🎜rrreee🎜Lassen Sie uns noch einmal einen Blick auf die <code>Personen-Tabelle werfen: 🎜rrreee🎜Die E-Mail und Telefon code>-Spalten wurden wie erwartet gelöscht. 🎜<h4 id="h4-4-oracle-alter-table-rename-">4. Beispiel für das Umbenennen einer Spalte</h4>🎜 Ab Version 9i hat Oracle eine Klausel zum Umbenennen von Spalten hinzugefügt, wie unten gezeigt: 🎜 rrreee🎜Zum Beispiel benennt die folgende Anweisung die Spalte <code>first_name in die Spalte forename um: 🎜rrreee🎜Die folgende Anweisung überprüft das Ergebnis: 🎜rrreee

🎜5. Beispiel für das Umbenennen einer Tabelle

🎜Um eine Tabelle in einen neuen name-Tabellennamen umzubenennen, verwenden Sie Folgendes Syntax: 🎜rrreee🎜Zum Beispiel benennt die folgende Anweisung die Tabelle users in die Tabelle people um: 🎜rrreee🎜Empfohlenes Tutorial: „🎜Oracle Tutorial🎜“ 🎜

Das obige ist der detaillierte Inhalt vonSo ändern Sie die Tabellenstruktur in Oracle. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage