天蝎承载梦想 2016-07-05 07:44 采纳率: 100%
浏览 4597
已采纳

oracle中为什么不能直接把一个序列设置为默认值?

create table jjj
(
ssd int default lol_seq.nextval primary key
);

就想上面的代码 ,为什么不行啊???

  • 写回答

1条回答 默认 最新

  • 我说假如 2016-07-05 07:52
    关注

    Oracle
    不直接支持 自动递增的列。
    需要创建一个序列 SEQUENCE。
    又由于无法在列的默认值那里,设置默认值为序列。因此只能通过触发器来设置。
    设置好触发器以后,所有的插入语句,将忽略外部传入的 id 数据,只使用指定的序列号来产生。

    CREATE SEQUENCE test_sequence2
    increment by 1 -- 每次递增1
    start with 1 -- 从1开始
    nomaxvalue -- 没有最大值
    minvalue 1 -- 最小值=1
    NOCYCLE; -- 不循环

    create table jjj
    (
    ssd int default test_sequence2.NEXTVAL primary key
    );

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置