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怎么设置? 展开
< id name="id" column="id">
< generator class="sequence">
< param name="sequence">序列名< /param>
< /generator> < /id>
在创建数据库时,id值不是通过自己手动输入设置吗?,那generator属性有什么用呢?回答的越详细越好!!
如果 设置< generator class="sequence"> ,那么我在oracle建立表时,id的值需要什么设置吗?
当class为别的值时,数据库中的表id怎么设置? 展开
6个回答
推荐于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()方法之前完成。适用的数据库根据选择的生成方式确定。
生成方式包括:
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()方法之前完成。适用的数据库根据选择的生成方式确定。
展开全部
这是用来设置主键生成策略的。
具体策略:
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值一样。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你的例子中表明 表的id列是一个自增序列 (< generator class="sequence"> ) , 使用数据库中的Sequence ( < param name="sequence">序列名< /param> )
当你插入数据时, id列会根据你的设置自动调用序列的值插入id列中
当你插入数据时, id列会根据你的设置自动调用序列的值插入id列中
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
一般id应该是唯一的,所以oracle 设计了序列,你可以在创建某个表时为其创建唯一的序列,此序列按照一定的规则产生唯一的id,在你添加记录时自动生成一个唯一的id给那张表。所以hibernate才有这个<generator>来设置你的oracle数据库表的对应的序列啊。
class为别的值时,有其他的属性啊,表其实可以没有序列的。可以看这篇文章
http://ryxxlong.iteye.com/blog/612446
class为别的值时,有其他的属性啊,表其实可以没有序列的。可以看这篇文章
http://ryxxlong.iteye.com/blog/612446
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
hibernate 的配置文件中generator 表示id 的生成方式,常用的有native ,increment等方式
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询