zoukankan      html  css  js  c++  java
  • 笔记 oracle 创建主键自增长

      笔记

      (1) 创建表

      create table test(

        id number(18,2) primary key, -- 主键(unique+not null)

        name varchar2(100) not null

      );

      (2) 创建序列

      create sequence seq_test_id 

      minvalue 1  -- 最小值
      start with 1  -- 起始值
      increment by 1  -- 步长
      nomaxvalue  --没有最大值,若有最大值则需要设置,maxvalue,相对的去掉nomaxvalue
      nocache    -- 不缓存序列,若需要缓存序列的话则改写成cache [number],number为整数,默认为20;

              -- 区别: cache 会在需要用到序列之前先缓存一定数量(默认20个)的序列到内存中,可以提高insert语句性能,但会存在跳号的问题,比如当缓存了20个,还剩5个,突然电脑断电,重启后,它会跳过剩下的5个序列,来取值
      nocycle;    -- 当达到最大值时,不循环使用序列值,循环的话则使用cycle

      (3) 创建触发器

      create or replace trigger trigger_test_id 
      before insert on test for each row when (new.id is null)
      begin
        select seq_test_id.nextval into :new.id from dual;
      end;

      尽管创建触发器很方便,但一般还是用另一种方式:

      hibernate的注解的形式更为方便,快捷,在实体类的主键列上添加注释,4步搞定:

        a. @Id    -- 标注主键列
        b. @Column(name = "id")    -- 标注属性与列的对应关系
        c. @SequenceGenerator(name = "seq_test", sequenceName = "seq_test_id", allocationSize = 1)     -- 标注sequenceName引用数据库中的序列"seq_test_id",并重命名为"seq_test"
        d. @GeneratedValue(generator = "sequence_resume_id", strategy = GenerationType.SEQUENCE)      --- 标注主键生成器和生成策略

      

      

  • 相关阅读:
    03-温故知新(下载网络资源)
    02-Inet套接字地址
    01-InetAddress常用方法
    递归删除文件夹跟拷贝文件夹
    File中常用的方法
    简单日志功能的实现
    简单二分查找算法
    应用打开其xlspptdoc等
    PPT文件分析摘记
    ReactNative小笔记
  • 原文地址:https://www.cnblogs.com/king-xg/p/6796918.html
Copyright © 2011-2022 走看看