sql – Hiberate问题,jdbc IDENTITY_INSERT设置为OFF

前端之家收集整理的这篇文章主要介绍了sql – Hiberate问题,jdbc IDENTITY_INSERT设置为OFF前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
当我尝试通过hibernate提交到sql Server时,我收到JDBC错误

Cannot insert explicit value for identity column in table ‘Report’ when IDENTITY_INSERT is set to OFF

我使用的netbeans生成的映射包含,

<class name="orm.generated.Report" table="Report" schema="dbo" catalog="DatabaseName">
    <id name="id" type="int">
        <column name="ID" />
        <generator class="assigned" />
    </id>

在我看来它应该正确地进行身份插入.

有关如何解决此问题的任何想法?

编辑:
一些链接到文档,为后代,
http://www.hibernate.org/hib_docs/v3/reference/en-US/html/mapping.html#mapping-declaration-id-generator
http://www.roseindia.net/hibernate/hibernateidgeneratorelement.shtml

解决方法

除非“IDENTITY_INSERT”设置为“ON”,否则无法插入sql Server中的标识列.由于您的生成器类是“已分配”,因此Hibernate假定您在保存对象之前在Java中为“id”设置显式值,并且Hibernate可以直接将值插入数据库.你需要:

>选择不同的生成器类,例如“native”>将IDENTITY_INSERT设置为“ON”

猜你在找的MsSQL相关文章