出现该错误,说明保存对象的主键没有自动生成,需要根据不同的数据库,设计主键的生成方式,例如:
[b]Oracle数据库:[/b]
在Hibernate的映射文件中,需要声明主键是根据序列自动生成的。
[b]SQLite数据库:[/b]
在Hibernate的映射文件中,需要声明主键是自增的。
关于主键generator 的类型,请参考文章:[b]《Hibernate 主键generator类型》[/b]
[url]http://javapub.iteye.com/blog/981993[/url]
[b]Oracle数据库:[/b]
在Hibernate的映射文件中,需要声明主键是根据序列自动生成的。
<id name="numitemid" type="java.lang.Integer">
<column name="NUMITEMID" precision="20" scale="0" />
<generator class="sequence">
<param name="sequence">SEQ_TL_COMMON_ITEM</param>
</generator>
</id>[b]SQLite数据库:[/b]
在Hibernate的映射文件中,需要声明主键是自增的。
<id name="numitemid" type="java.lang.Integer">
<column name="NUMITEMID" precision="20" scale="0" />
<generator class="increment"></generator>
</id>关于主键generator 的类型,请参考文章:[b]《Hibernate 主键generator类型》[/b]
[url]http://javapub.iteye.com/blog/981993[/url]
本文介绍了在使用不同数据库(如Oracle和SQLite)时如何通过配置Hibernate的映射文件来实现主键的自动生成。针对Oracle数据库,可以通过设置序列来生成主键;而对于SQLite数据库,则可以配置主键为自增。
534

被折叠的 条评论
为什么被折叠?



