首页 > 其他分享 >ORA-01440: 要减小精度或标度, 则要修改的列必须为空问题修复

ORA-01440: 要减小精度或标度, 则要修改的列必须为空问题修复

时间:2022-10-12 22:59:01浏览次数:69  
标签:12 01440 money bak 为空 table table01 alter ORA

环境准备:

使用oracle数据库:

create table table01 (
  id number(16) not null,
  name varchar2(50) default null,
  money number(12,6) default null,
  primary key (id)
);

select * from table01;

insert into table01 (id,name,money) values (1,'一路',200000.12);
————————————————
版权声明:本文为CSDN博主「一 路」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/li02112017/article/details/108678703

  查询数据:

 

在上面的例子中money字段初始设置是number(12,6),即可以允许6位整数,6为小数;工作中可能由于某些原因要修改money这个字段的

精度,例如需要改成只保留2为小数,然后整数为10为,即要修改成number(12,2);

我们使用sql:

alter table table01 modify money number(12,2);

  发现报错:

 

 我们要减小精度或标度, 则要修改的列必须为空,而我们本来表中是存在数据的,那么直接alter修改字段是会报错的;

解决方法:

1.先将字段重命名

 

 alter table table01 rename column money to money_bak;

 

2.在新增一列 money,并改成要修改的精度

alter table table01 add(money number(12,2));

 

 

 3.将money_bak的值赋值给money列

update table01 set money = trim(money_bak);

 

 4.删除money_bak列

alter table table01 drop column money_bak;

 

 

 

 这样我们就将money字段的精度修改成number(12,2);

使用四条sql就可以修改字段的精度:

alter table table01 rename column money to money_bak;

alter table table01 add(money NUMBER(12,2));

update table01 set money = trim(money_bak);

alter table table01 drop column money_bak;

题外话:当然如果工作中数据很重要的话,建议对修改的表先进行备份,然后在执行上面的sql进行修改;

 

转自:(4条消息) ORA-01440: 要减小精度或标度, 则要修改的列必须为空问题修复_一 路的博客-CSDN博客_ora-01440

标签:12,01440,money,bak,为空,table,table01,alter,ORA
From: https://www.cnblogs.com/wwssgg/p/16786417.html

相关文章

  • oracle修改字段类型报错ORA-01439: column to be modified must be empty to change d
    可用如下方式,都是一样的,修改字段类型的列的数据必须为空!ORA-01440:要减小精度或标度,则要修改的列必须为空问题修复-信铁寒胜-博客园(cnblogs.com) ......
  • 【Vegas原创】Oracle Dblink(链接服务器)创建(Oracle对Oracle的链接)以及SQL对Oracle的互
    Oracle对Oracle的链接:创建:CREATEPUBLICDATABASELINKlinknameCONNECTTOusernameIDENTIFIEDBYpasswordUSING‘tnsname’删除:DROPPUBLICDATABASELINKlin......
  • 判断map集合是否为空和是否为null
    转:判断map集合是否为空和是否为null    ......
  • Typora
    目录输入[toc]然后回车,即可创建一个“目录”。TOC从文档中提取所有标题,其内容将自动更新。目录目录教程认识手写定义格式分隔线---代码块无序列表有序列表引用>快捷......
  • 使用java代码连接oracle
    Connectionconn=null;try{Class.forName("oracle.jdbc.OracleDriver");//数据库IPStringip="oracle数据库IP地址或者是localhost";//数据库......
  • MarkDown文件与Tyora编辑器第一次正式使用笔记
    第一次正式使用Tyora编辑器,记录MarkDown文件常用的语法。MarkDown文件后缀为.md;和文本文件一样简单,比文本文件强大,有常用的样式。Tyora编辑器可以编辑md文件,0.11.8为免费......
  • oracle 21c expdp报错误UDE-31623
     环境:OS:Centos7DB:21C 导出报错expdpc##goldengate/goldengate@tnspdb1tables=hxl.tb_testdumpfile=tb_test.dmpFLASHBACK_SCN=4990304parallel=5direct......
  • Fedora安装mariadb
    开始想安装mysql,有2002错误一直解决不了,各种百度没有效果,装了下maria能装成功,因为maria是基于mysql的,也有那个错误,不过一个命令就解决了。安装:yuminstallmysql-server启......
  • CVPR2022 Oral OGM-GE阅读笔记
    标题:BalancedMultimodalLearningviaOn-the-flyGradientModulation(CVPR2022Oral)论文:https://arxiv.org/abs/2203.15332领域:多模态学习解决本质问题在某些多模态......
  • oracle数据泵
    /*1)逻辑备份恢复:数据泵2)物理备份恢复:Rman数据泵技术(源端-》目标端)源端启动DataPumpJob(expdp)目标端启动DataPumpJob(impadp)1)数据泵核心部分程序包......