为了账号安全,请及时绑定邮箱和手机立即绑定

请问hibernate中的<generater class="native">什么意思?

/ 猿问

请问hibernate中的<generater class="native">什么意思?

杨魅力 2019-07-02 10:06:50

hibernate中的<generater class="native">什么意思


查看完整描述

5 回答

?
DIEA

hibernate 的配置文件中generator 表示id 的生成方式,常用的有native ,increment等方式

查看完整回答
反对 回复 2019-07-06
?
素胚勾勒不出你

native有天生的,本土的,也就是说生来就有的,
那也就是说自动生成,不需要人工来帮忙或者管控的.

而assigned是指指定的,分配的,
如果你不赋予他甚麼东西,那麼他是不能实现的.
需要人工,自己把某个东西赋予给它
所以是assigned

在用Hibernate的时候,当有表中的主键是库自动生成的时候将使用native。
<generator class="native"></generator>
而当是自己添加的时候则需要改为assigned。
<generator class="assigned"></generator>
否则将会出现异常!

如果建表时,该表主键类型是integer,并设置成auto-increment,用native;该表主键类型是string类型的,用uuid.hex

查看完整回答
反对 回复 2019-07-06
?
九州编程

<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()方法之前完成。适用的数据库根据选择的生成方式确定。

查看完整回答
反对 回复 2019-07-06
?
慕标5265247

这是用来设置主键生成策略的。

 

具体策略:

 

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值一样。


查看完整回答
反对 回复 2019-07-06
?
12345678_0001

一般id应该是唯一的,所以oracle 设计了序列,你可以在创建某个表时为其创建唯一的序列,此序列按照一定的规则产生唯一的id,在你添加记录时自动生成一个唯一的id给那张表。所以hibernate才有这个<generator>来设置你的oracle数据库表的对应的序列啊。
class为别的值时,有其他的属性啊,表其实可以没有序列的。

查看完整回答
反对 回复 2019-07-06

添加回答

回复

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信