oracle11g建表使用GENERATED和seq报错ORA-02000:missing ALWAYS keyword或ORA-00984: column not allowed here

一、
1、问题场景
开发环境,oracle11g。开始使用脚本创建表

CREATE TABLE regions
  (
    region_id NUMBER GENERATED BY DEFAULT AS IDENTITY
    START WITH 5 PRIMARY KEY,
    region_name VARCHAR2( 50 ) NOT NULL
  );

oracle建表报错:ORA-02000:missing ALWAYS keyword
百度之后

https://blog.csdn.net/u014285237/article/details/128674668
https://blog.csdn.net/weixin_42675423/article/details/127093117

修改sql为

create sequence regions_seq;
CREATE TABLE regions
  (
    region_id NUMBER DEFAULT regions_seq.nextval,
    region_name VARCHAR2( 50 ) NOT NULL
  );

报错

ORA-00984: column not allowed here
继续百度,找到原因

https://www.656463.com/wenda/Oraclelbyxccmrzzf_592
https://blog.csdn.net/weixin_32534073/article/details/116336946

最终发现自增主键也是12c才有的功能,总结,只能使用触发器实现。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值