您现在的位置是:群英 > 数据库 > 关系型数据库
oracle中用什么语句修改表字段类型,如何写
Admin发表于 2022-08-09 17:55:211079 次浏览
今天这篇给大家分享的知识是“oracle中用什么语句修改表字段类型,如何写”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“oracle中用什么语句修改表字段类型,如何写”文章能帮助大家解决问题。



在oracle中,可以使用“alter table”语句来修改表字段类型,该语句的作用就是改变原有表的结构,语法“alter table 表名 modify (字段名 新类型名);”语句。

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

修改表字段数据类型

有一个表名为tb,字段段名为name,数据类型nchar(20)。

1、假设字段数据为空,则不管改为什么字段类型,可以直接执行:

alter table tb modify (name nvarchar2(20));

2、假设字段有数据,则改为nvarchar2(20)可以直接执行:

alter table tb modify (name nvarchar2(20));

3、假设字段有数据,则改为varchar2(40)执行时会弹出:“ORA-01439:要更改数据类型,则要修改的列必须为空”,这时要用下面方法来解决这个问题:

/*修改原字段名name为name_tmp*/

alter table tb rename column name to name_tmp;

/*增加一个和原字段名同名的字段name*/

alter table tb add name varchar2(40);

/*将原字段name_tmp数据更新到增加的字段name*/

update tb set name=trim(name_tmp);

/*更新完,删除原字段name_tmp*/

alter table tb drop column name_tmp;

3.添加字段以及删除字段

    --添加新的字段

    alter table lyz_emp add(e_age number(3));

    --添加多个新的字段

    alter table lyz_emp add(

    e_age number(3),

    e_age_tmp,varchar2(20));

    --获取表字段:

    select *

    from user_tab_columns

    where Table_Name='lyz_emp'

    order by column_name

    --删除表中的字段

    alter table lyz_emp drop column e_age;

以上就是关于“oracle中用什么语句修改表字段类型,如何写”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注群英网络,小编每天都会为大家更新不同的知识。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

相关信息推荐
2022-05-14 11:37:25 
摘要:在mysql中,可以利用UPDATE命令修改内容,该命令用于修改或更新MySQL中的数据,利用该命令可以同时修改一个或多个内容,语法为“UPDATE 表名 SET field1=new-value1,field2=new-value2”。
2022-09-14 17:54:58 
摘要:本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于一条update语句是怎样执行的相关问题,执行update更新操作时,跟表有关的查询缓存会失效,所以语句就会把表上所有缓存结果都清空,下面就一起来看一下,希望对大家有帮助。
2022-08-09 17:54:49 
摘要:oracle系统是以Oracle关系数据库为数据存储和管理作为构架基础,构建出的数据库管理系统;Oracle是由甲骨文公司开发出来的,Oracle公司的整个产品线包括数据库服务器、企业商务应用套件、应用开发和决策支持工具。
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部