hibernate 中用sequnce 生成主键值

1、在oracle 首先创建sequence

       create sequence seq_payment
      minvalue 1
      start with 1
      increment by 1
      cache 20;

   2.在你的entity中的配置
   
  1. @Id  
  2. @GeneratedValue(strategy = GenerationType.SEQUENCE,generator="payablemoney_seq")   
  3. @SequenceGenerator(name="payablemoney_seq", sequenceName="seq_payment")  
     

       这样再插入数据的时候,Hibernate回自动生成如下语句:
       
       hibernate: select seq_id.nextval from dual

   hibernate:  insert into YXJK.T_YXJK_WHRYTXL (XM0000, ZW0000, LXDH00, SJHM00, DZYJ00,   
                    IP0000,     ID0000) values (?, ?, ?, ?, ?, ?, ?)

   自动生成下一个序列值,然后将对象插入表中。
   在使用的时候需要注意,Hibernate对于sequence的主键的要求是一定要是shor,long,或者integer

 

想自己去拿的话可以采用下面这种方法

 

List results =entityManager.createNativeQuery("select BCF_SEQ1.NEXTVAL from DUAL").getResultList();
        int id_seq = ((BigDecimal) results.get(0)).intValue();

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值