hibernate映射 generator class="identity" 是什么是意思
2个回答
2013-05-03
展开全部
是的!从一开始递增,好像不能用在oracle吧!identity对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。sequence支持oracle!!
http://blog.csdn.net/dy511/article/details/6175257
http://blog.csdn.net/dy511/article/details/6175257
Storm代理
2023-08-29 广告
2023-08-29 广告
"StormProxies是全球大数据IP资源服务商,其住宅代理网络由真实的家庭住宅IP组成,可为企业或个人提供满足各种场景的代理产品。点击免费测试(注册即送1G流量)StormProxies有哪些优势?1、IP+端口提取形式,不限带宽,I...
点击进入详情页
本回答由Storm代理提供
展开全部
< class name="onlyfun.caterpillar.User" table="USER">
< id name="id" type="string" unsaved-value="null">
< column name="USER_ID"/>
< generator class="uuid.hex"/>
< /id>
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>
< id name="id" type="string" unsaved-value="null">
< column name="USER_ID"/>
< generator class="uuid.hex"/>
< /id>
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>
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询