通过表的生成主键序列(seqence)

通过一个表SEQUENCE:
--序列表
CREATE TABLE SEQUENCE (
       SEQ_NAME VARCHAR2(50), /*序列名*/
       SEQ_COUNT NUMBER(8,0)  /*序列*/
)
/
代码如下:


@Entity
/*定义生成器,对应于SEQUENCE表中SEQ_NAME字段为user_seq的一行*/
@TableGenerator(name="USER_TABLE_GENERATOR",
    table="SEQUENCE", pkColumnValue="user_seq",valueColumnName="SEQ_COUNT", pkColumnName="SEQ_NAME")   
@NamedQueries({
@NamedQuery(name = "User.findAll", query = "select o from User o"),
@NamedQuery(name = "User.findByUserName",
query = "select o from User o where o.userName = :userName "),
@NamedQuery(name = "User.findByUserId",
query = "select o from User o where o.id = :id ")
})
@Table(name = "USERS")
public class User implements Serializable {
    @Column(name="CANCEL_TIME")
    private Timestamp cancelTime;
    @Column(name="CREATE_TIME")
    private Timestamp createTime;
   
    @Id
/*引用生成器*/
    @GeneratedValue(strategy=GenerationType.TABLE,generator="USER_TABLE_GENERATOR")   

    @Column(nullable = false)
    private Long id;

.........

使用时请在SEQUENCE中添加相应的记录。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值