ORA-00913错误:PL/SQL: ORA-00913: too many values

ORA-00913错误


描述:PL/SQL: ORA-00913: too many values


目标:编写一个可以循环插入数据的脚本


操作过程:

SQL> desc tcustmer
Name               Null?    Type
 ----------------- -------- ----------------------------
 CUST_CODE         NOT NULL VARCHAR2(10)
 NAME                       VARCHAR2(30)
 CITY                       VARCHAR2(20)
 STATE                      CHAR(2)


SQL>CREATE SEQUENCE tcustmer_cust 
      INCREMENT BY 1
      START WITH 1
      MAXVALUE 100000000
      CACHE 10000
      NOCYCLE; 
      
SQL> begin
  2       for i in 1..10 loop
  3         insert into tcustmer
  4         values (tcustmer_cust.nextval,'T','test'||i,'BEIJING','CN');
  5         if mod(i,10)=0 then 
  6         commit;
  7         end if;
  8      end loop;
  9      commit;
 10  end;
 11  /
       insert into tcustmer
                   *
ERROR at line 3:
ORA-06550: line 3, column 20:
PL/SQL: ORA-00913: too many values
ORA-06550: line 3, column 8:
PL/SQL: SQL Statement ignored


检查发现插入的values值,列数超过了tcustmer表的列数
调整如下:
SQL>begin
     for i in 1..10 loop
       insert into tcustmer
       values ('T'||tcustmer_cust.nextval,'test'||i,'BEIJING','CN');
       if mod(i,10)=0 then 
       commit;
       end if;
    end loop;
    commit;
end;
/
PL/SQL procedure successfully completed.

总结:

    对于tcustmer_cust.nextval理解错误,创建序列的目的正是消除主键的干扰,所以在使用的时候需要将其放到列值中。



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值