0

0

如何在数据字典中修改Oracle的表列名

php中文网

php中文网

发布时间:2016-06-07 15:45:51

|

1223人浏览过

|

来源于php中文网

原创

如何在数据字典中修改Oracle的表列名 在oracle数据库中没有提供直接修改表中列名称的功能,但在实际使用时常需要修改表的列名和列顺序这一情况下,本文给出了从数据字典中直接修改表列的名称和顺序的方法,供大家参考! AD:51CTO学院:IT精品课程在线看!

如何在数据字典中修改Oracle的表列名


在oracle数据库中没有提供直接修改表中列名称的功能,但在实际使用时常需要修改表的列名和列顺序这一情况下,本文给出了从数据字典中直接修改表列的名称和顺序的方法,供大家参考!

AD:51CTO学院:IT精品课程在线看!

在Oracle数据库中没有提供直接修改表中列名称的功能,但在实际使用时常需要修改表的列名和列顺序,在不得已的情况下,有些Oracle的使用者用重新创建一个新的具有正确列名和顺序的数据库表,再将旧表的数据转储进来,最后删除旧表并将新表重命名为旧表的方法来完成此功能。此方法的最大问题是要求有双倍的存储空间、较大的回滚段和较长的时间,如果表中数据量较大,这项工作开销会很大。实际上我们可以从数据字典中直接修改表列的名称和顺序。下面是实现的具体步骤:

1、以internal用户名登录Oracle数据库,并创建一测试表。

@@######@@
 
下面需要要把SCOTT.TEST表中EMPNO和ENAME两列调换顺序,并把ENAME列更名为EMP_NAME,EMPNO改为EMP_NO。

2、查询表中列的实际存储位置或表。

@@######@@

由于TEXT列是LONG类型,只有“SET”之后才能完全显示。

@@######@@

数据字典视图USER_TAB_COLUMNS中存储有表列的定义信息,从该语句的查询结果可以看出,列定义信息是存储在表SYS.COL$中的,即如果修改表中列的定义,应该在SYS.COL$表中修改。

3、从数据字典视图ALL_OBJECTS中查找对象SCOTT.TEST对象ID。

@@######@@

4、根据SCOTT.TEST对象的ID,从SYS.COL$检索出表中列的定义信息。

@@######@@

5、使用Update语句来进行修改。

ListenHub
ListenHub

超真实的AI播客生成器

下载
@@######@@

6、重启数据库服务。

由于数据字典是在数据库启动时加载到SQL中的,所以修改了它之后,如果使用“SELECT * FROM SCOTT.TEST; ”,会发现好像并没有修改。因此,修改完成之后,还需要重启数据库服务。

@@######@@

这时,再查看,就会发现修改已经成功。

@@######@@

这种方法直接从数据库中进行表列定义的修改,存在一定风险,但它对于数据量特别大的表是非常有用的。充分利用数据字典功能,往往能够完成日常很难完成的工作。下面笔者写了一段简单的存储过程,可实现表中列的重命名。大家可以直接调用这个过程来完成列的重命名:

@@######@@

  • Oracle数据库密码文件的使用和维护
  • 利用Oracle管理服务器将数据导入导出
  • 全面认识Oracle数据库字符集



参考:

Oracle中修改表列名,用SQL语句的方式》所用的修改表列名的方式是一个集成操作,执行该文所说的方式的具体过程,其实质是在做本文中里提到的那些内部修改操作。即《Oracle中修改表列名,用SQL语句的方式》的操作是表象,而本文中所做的操作才是本质。

Oracle中修改表列名,用SQL语句的方式


SQL>CREATE TABLE SCOTT.TEST AS SELECT EMPNO,
ENAME FROM SCOTT.EMP;
SQL>DESC SCOTT.TEST 
Name Type Nullable Default Comments 
------- ------------ ------- 
EMPNO NUMBER(4) Y 
ENAME VARCHAR2(10) Y
SQL>SET LONG 9999

SQL>SELECT TEXT FROM ALL_VIEWS WHERE VIEW_NAME = ‘USER_TAB_COLUMNS’;

SQL> SELECT * FROM ALL_OBJECTS WHERE OWNER =‘SCOTT’ AND OBJECT_NAME=‘TEST’;

SQL> SELECT OBJ#,COL#,NAME FROM SYS.COL$ WHERE OBJ# =13888;
OBJ# COL# NAME
---------- ---------- -------
13888 1 EMPNO
13888 2 ENAME

UPDATE SYS.COL$ SET COL# = 2,NAME=‘EMP_NO’ WHERE OBJ# = 13888 AND NAME=‘EMPNO’; UPDATE SYS.COL$ SET COL# = 1,NAME=‘EMP_NAME’ WHERE OBJ# = 13888 AND NAME =‘ENAME’; COMMIT;

SQL>SHUTDOWN
SQL>STARTUP

SQL> SELECT * FROM SCOTT.TEST; EMP_NAME EMP_NO ---------- ------ SMITH 7369 ALLEN 7499 WARD 7521 ……

SQL>exec altercolname (‘模式名称’,‘表名称’,‘原列名称’,‘新列名称’); create or replace procedure sys.altercolname (schmaname in varchar2, tabname in varchar2, oldcolname in varchar2, newcolname in varchar2) is n_schmaname varchar2(30); --模式名称 n_tablename varchar2(30); --表名称 n_oldcolname varchar2(30); --原来列名称 n_newcolname varchar2(30); --新的列名称 n_objnum number; begin n_schmaname := upper(schmaname); n_tablename := upper(tabname); n_oldcolname := upper(oldcolname); n_newcolname := upper(newcolname); SELECT OBJECT_ID INTO n_objnum FROM ALL_OBJECTS WHERE OWNER = n_schmaname AND OBJECT_NAME=n_tablename; UPDATE SYS.COL$ SET NAME=n_newcolname WHERE OBJ# = n_objnum AND NAME=n_oldcolname; COMMIT; end altercolname;

相关专题

更多
高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

84

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

24

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

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

35

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

16

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

56

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

16

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

9

2026.01.15

ppt一键生成相关合集
ppt一键生成相关合集

本专题整合了ppt一键生成相关教程汇总,阅读专题下面的的文章了解更多详细内容。

26

2026.01.15

热门下载

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

精品课程

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

共48课时 | 7.3万人学习

Excel 教程
Excel 教程

共162课时 | 12.2万人学习

Kotlin 教程
Kotlin 教程

共23课时 | 2.6万人学习

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

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