0

0

oracle怎么修改表结构

青灯夜游

青灯夜游

发布时间:2022-01-13 11:15:45

|

11293人浏览过

|

来源于php中文网

原创

在oracle中,可以使用“ALTER TABLE”语句来修改表结构,该语句可以通过增加或删减列、更改原有列类型、重新命名列或表等方式来改变原有表的结构,语法“ALTER TABLE 表名 [修改选项]”。ALTER TABLE 表名 [修改选项]

oracle怎么修改表结构

本教程操作环境:Windows7系统、Oracle 11g版、Dell G3电脑。

oracle中,可以使用“ALTER TABLE”语句来修改表结构。

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

ALTER TABLE 语句的语法:

ALTER TABLE 表名 [修改选项]

在上面的语句中,

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

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

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)
);

1. 添加列的例子

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

ALTER TABLE table_name
ADD column_name type constraint;

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

ALTER TABLE persons 
ADD birthdate DATE NOT NULL;

如果查看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

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

ALTER TABLE table_name
ADD (
    column_name type constraint,
    column_name type constraint,
    ...
);

看下面的例子:

ALTER TABLE persons 
ADD (
    phone VARCHAR(20),
    email VARCHAR(100)
);

在这个例子中,语句在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)

2. 修改列的属性的示例

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

ALTER TABLE table_name
  MODIFY column_name type constraint;

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

ALTER TABLE persons MODIFY birthdate DATE NULL;

我们再次验证persons表结构:

云网OA
云网OA

采用JSP开发的办公自动化产品、基于B/S结构,运行环境:JDK v1.5、Tomcat v5.5、MySQL v4.1,三者均为以上版本其他相关内容:可视化流程设计: 流程支持串签、会签和分支流程,可以设置流程节点的修改、删除权限,并可指定流程中各个用户在表单中可以填写的域。智能表单所见即所得设计: 智能设计,自动在数据库中生成表格,方便优化程序 公共交流: 集论坛、博客、聊天室于一体文件柜:C

下载
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)

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

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

 ALTER TABLE table_name
  MODIFY ( column_1 type constraint,
          column_1 type constraint,
         ...);

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

ALTER TABLE persons MODIFY(
    phone VARCHAR2(20) NOT NULL,
    email VARCHAR2(255) NOT NULL
);

再次验证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)

3. 删除现有的列的示例

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

ALTER TABLE table_name
DROP COLUMN column_name;

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

ALTER TABLE persons
DROP
  COLUMN birthdate;

再次查看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)

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

ALTER TABLE table_name 
DROP (column_1,column_2,...);

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

ALTER TABLE persons
DROP
  ( email, phone );

我们再来看一下persons表:

DESC persons;

Name       Null     Type         
---------- -------- ------------ 
PERSON_ID  NOT NULL NUMBER       
FIRST_NAME NOT NULL VARCHAR2(50) 
LAST_NAME  NOT NULL VARCHAR2(50)

emailphone列已按预期删除。

4. 重命名列的示例

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

ALTER TABLE table_name
RENAME COLUMN column_name TO new_name;

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

ALTER TABLE persons 
RENAME COLUMN first_name TO forename;

以下语句检查结果:

DESC persons;

Name      Null     Type         
--------- -------- ------------ 
PERSON_ID NOT NULL NUMBER       
FORENAME  NOT NULL VARCHAR2(50) 
LAST_NAME NOT NULL VARCHAR2(50)

5. 重命名表的例子

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

ALTER TABLE table_name
RENAME TO new_table_name;

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

ALTER TABLE persons RENAME TO people;

推荐教程:《Oracle教程

相关专题

更多
云朵浏览器入口合集
云朵浏览器入口合集

本专题整合了云朵浏览器入口合集,阅读专题下面的文章了解更多详细地址。

0

2026.01.20

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

20

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

62

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

87

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

39

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

19

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

160

2026.01.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.5万人学习

Java 教程
Java 教程

共578课时 | 48.4万人学习

oracle知识库
oracle知识库

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号