Hibnernate 的主键类型

       Hibernate 提供了多种的主键生成方法。这里我做简单的介绍。PS:这不是让人看得,这是让我忘记的时候给自己提个醒。嘻嘻

       1)Assigned:主键由应用程序设置。相信使用的次数相当相当的少啊~

       2)hilo:不懂。因此我绝对不会用的。

       3)seqhilo:和hilo 差不多。因此也不懂,所以还是不会的。

       4)increment:主键按数值顺序递增。因此在第一次插入数据前Hibernate 会先使用sql 语句查找出最大的主键值,然后进行插入。该方法的一个缺陷是不支持多线程。当同时插入数据时将发生错误。但是还是有用的时候。比如数据导入的时候。

       5)identity:采用数据库的主键生成机制。sql server 和mysql 用的比较的多。

       6) sequence:数据库使用sequence 机制生成主键。我只在oracle 中使用过。(才疏学浅,对不起大家了)。

       7)native:Hibernate会根据定义的适配器采用identity,hilo,sequence 的其中一种主键生成机制。

       8)uuid.hex:由Hibernate 的算法生成主键。根据设备的IP,时间,JVM启动时间生成一个十六进制的数值。优点:性能好和可以跨数据库。

       9)uuid.string:和uuid.hex一样。只是它没有将生成的数值转换成十六进制。

       10)foreign:使用表的外键设置为主键。形成两张表的一对一关系。

       11)select:不知道。Hibnernate 3 新引入的。谁知道谁告诉我。谢谢大家了。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值