Hibernate的generator属性,不明白这个有什么用?

Hibernate的generator属性,不明白这个有什么用?比如<idname="id"column="id"><generatorclass="sequence">... Hibernate的generator属性,不明白这个有什么用?比如
< id name="id" column="id">
< generator class="sequence">
< param name="sequence">序列名< /param>
< /generator> < /id>

在创建数据库时,id值不是通过自己手动输入设置吗?,那generator属性有什么用呢?回答的越详细越好!!
如果 设置< generator class="sequence"> ,那么我在oracle建立表时,id的值需要什么设置吗?

当class为别的值时,数据库中的表id怎么设置?
展开
 我来答
匿名用户
推荐于2017-11-26
展开全部
<generator>表示一个主键的生成机制。即具体通过何种方式来生成。
生成方式包括:
increment:生成long, short或者int类型的主键,不能在cluster环境下使用。适用于所有数据库
identity:生成long, short或者int类型的主键。适用于DB2, MySQL, MS SQL Server, Sybase and HypersonicSQL
sequence :生成long, short或者int类型的主键。适用于DB2, PostgreSQL, Oracle, SAP DB, McKoi,Interbase.
hilo:生成long, short或者int类型的主键。需要提供一个数据库的表来存放生成的主键信息。当采用应用服务器的JTA提供的数据库连接或者用户自定义的数据库连接的时候,不要使用这种主键生成方式。适用于所有数据库
seqhilo:采用给定的数据库的sequence来生成long, short或者int类型的主键。适用于DB2, PostgreSQL, Oracle, SAP DB, McKoi,Interbase.

uuid.hex:采用128位的算法来生成一个32位字符串。最通用的一种方式。适用于所有数据库
uuid.string:同样采用128位的UUID算法。将生成的字符编码位16位。适用于除PostgreSQL.以外的数据库
native:根据具体连接的数据库从identity, sequence或者hilo选择一种来生成主键。适用的数据库根据选择的生成方式确定。
assigned: 交给应用自己给主键赋值。要注意的是赋值必须在调用save()方法之前完成。适用的数据库根据选择的生成方式确定。
kevintop3
2013-09-17 · TA获得超过1.5万个赞
知道小有建树答主
回答量:890
采纳率:100%
帮助的人:530万
展开全部
这是用来设置主键生成策略的。

具体策略:

Hibernate的Generator属性有7种class,本文简略描述了这7种class的意义和用法。
1、identity:用于MySql数据库。特点:递增 
< id name="id" column="id">       < generator class="identity"/>   < /id> 
注:对于MySql数据库使用递增序列时需要在建表时对主键指定为auto_increment属性。
2、sequence:用于Oracle数据库 
< id name="id" column="id">      < generator class="sequence">        < param name="sequence">序列名< /param>      < /generator>   < /id> 
3、native:跨数据库时使用,由底层方言产生。 
Default.sequence为hibernate_sequence
< id name="id" column="id">      < generator class="native"/>   < /id>   
注:使用native时Hibernate默认会去查找Oracle中的hibernate_sequence序列。 
如果Oracle中没有该序列,连Oracle数据库时会报错。
4、hilo:通过高低位合成id,先建表hi_value,再建列next_value。必须要有初始值。
< id name="id" column="id">       < generator class="hilo">         < param name="table">high_val< /param>          < param name="column">nextval< /param>         < param name="max_lo">5< /param>       < /generator>   < /id>  
5、sequencehilo:同过高低位合成id,建一个sequence序列,不用建表。 
< id name="id" column="id">   < generator class="hilo">   < param name="sequence">high_val_seq< /param>   < param name="max_lo">5< /param>   < /generator>   < /id> 
6、assigned:用户自定义id; 
< id name="id" column="id">   < generator class="assigned"/>   < /id> 
7、foreign:用于一对一关系共享主健时,两id值一样。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jackylvxg
2013-09-17 · TA获得超过243个赞
知道小有建树答主
回答量:386
采纳率:0%
帮助的人:216万
展开全部
你的例子中表明 表的id列是一个自增序列 (< generator class="sequence"> ) , 使用数据库中的Sequence ( < param name="sequence">序列名< /param> )

当你插入数据时, id列会根据你的设置自动调用序列的值插入id列中
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
yisuoyanyu111
2013-09-17 · 超过16用户采纳过TA的回答
知道答主
回答量:57
采纳率:0%
帮助的人:33.5万
展开全部
一般id应该是唯一的,所以oracle 设计了序列,你可以在创建某个表时为其创建唯一的序列,此序列按照一定的规则产生唯一的id,在你添加记录时自动生成一个唯一的id给那张表。所以hibernate才有这个<generator>来设置你的oracle数据库表的对应的序列啊。
class为别的值时,有其他的属性啊,表其实可以没有序列的。可以看这篇文章
http://ryxxlong.iteye.com/blog/612446
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
liummhh
2013-09-17
知道答主
回答量:13
采纳率:0%
帮助的人:1.8万
展开全部
hibernate 的配置文件中generator 表示id 的生成方式,常用的有native ,increment等方式
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式