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


    环境准备:

    使用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

  • 相关阅读:
    家庭记账本开发记录2
    家庭记账本开发记录1
    构建之法阅读笔记——具体职位、用户和行业篇
    构建之法阅读笔记——团队篇
    js学习17
    js学习15
    js学习14
    js学习13
    js学习12
    js学习11
  • 原文地址:https://www.cnblogs.com/wwssgg/p/16786417.html
Copyright © 2020-2023  润新知