gpt4 book ai didi

java - 持久化实体时出现 SQLServerException - 索引超出范围

转载 作者:行者123 更新时间:2023-12-02 04:31:06 28 4
gpt4 key购买 nike

我在持久保留与另一个实体具有 @OneToOne 关系的实体时遇到问题。我们最近使用 Spring 4 和 Hibernate 4 升级到了 Java 8,所以我确信有一些注释或配置发生了变化。

相关代码

PermitState.java:

@Entity
@Table(schema = "dbo", name = "PermitState")
public class PermitState implements Serializable {

private String oid;
private Permit permit;
private Integer invoiced;
private Integer used;
private Integer ordered;
private String permitId;


@OneToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "PERMITID")
public Permit getPermit() {
return permit;
}

@Id
@Column(name = "PERMITID", nullable = true, length = 8,insertable = false,updatable = false)
public String getPermitId() {
return permitId;
}

... more getters and setters (irrelevant)

Permit.java:

@Entity
@Table(schema = "dbo")
public class Permit {

private String permitid;
private PermitState permitState;


...some more attributes, irrelevant


@Id
@Column(name = "PERMITID", length = 8)
public String getPermitid() {
return permitid;
}

@OneToOne(mappedBy="permit", cascade=CascadeType.ALL,fetch = FetchType.LAZY)
public PermitState getPermitState() {
return permitState;
}

堆栈跟踪

Caused by: org.hibernate.exception.GenericJDBCException: could not insert: [dao.srs.model.PermitState]
at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:54)
at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:124)
at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:3099)
at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:3521)
at org.hibernate.action.internal.EntityInsertAction.execute(EntityInsertAction.java:88)
at org.hibernate.engine.spi.ActionQueue.execute(ActionQueue.java:395)
at org.hibernate.engine.spi.ActionQueue.executeActions(ActionQueue.java:387)
at org.hibernate.engine.spi.ActionQueue.executeActions(ActionQueue.java:303)
at org.hibernate.event.internal.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventListener.java:349)
at org.hibernate.event.internal.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:56)
at org.hibernate.internal.SessionImpl.flush(SessionImpl.java:1195)
at org.hibernate.internal.SessionImpl.managedFlush(SessionImpl.java:404)
at org.hibernate.engine.transaction.internal.jdbc.JdbcTransaction.beforeTransactionCommit(JdbcTransaction.java:101)
at org.hibernate.engine.transaction.spi.AbstractTransactionImpl.commit(AbstractTransactionImpl.java:175)
at org.hibernate.ejb.TransactionImpl.commit(TransactionImpl.java:75)
at org.springframework.orm.jpa.JpaTransactionManager.doCommit(JpaTransactionManager.java:515)
... 65 more
Caused by: com.microsoft.sqlserver.jdbc.SQLServerException: The index 6 is out of range.
at com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDriverError(SQLServerException.java:171)
at com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement.setterGetParam(SQLServerPreparedStatement.java:700)
at com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement.setValue(SQLServerPreparedStatement.java:709)
at com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement.setString(SQLServerPreparedStatement.java:1034)
at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.setString(NewProxyPreparedStatement.java:963)
at org.hibernate.type.descriptor.sql.VarcharTypeDescriptor$1.doBind(VarcharTypeDescriptor.java:57)
at org.hibernate.type.descriptor.sql.BasicBinder.bind(BasicBinder.java:93)
at org.hibernate.type.AbstractStandardBasicType.nullSafeSet(AbstractStandardBasicType.java:284)
at org.hibernate.type.AbstractStandardBasicType.nullSafeSet(AbstractStandardBasicType.java:279)
at org.hibernate.type.ComponentType.nullSafeSet(ComponentType.java:343)
at org.hibernate.persister.entity.AbstractEntityPersister.dehydrateId(AbstractEntityPersister.java:2835)
at org.hibernate.persister.entity.AbstractEntityPersister.dehydrate(AbstractEntityPersister.java:2804)
at org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:3076)
... 78 more

正如您所看到的,PermitState 实体既与 Permit 相关(通过 PERMITID,它是 Permit 中的 PK),又具有一个名为 PermitId 的字段,该字段应该是连接的 Permit 的 ID。但这似乎不起作用,它似乎正在尝试插入所有 6 个属性,即使 Permit 不应插入数据库中。我尝试使用 @Transient 注释 PermitState 中的 Permit,但随后出现 AnnotationException:

Caused by: org.hibernate.AnnotationException: Unknown mappedBy in: dao.srs.model.Permit.permitState, referenced property unknown: dao.srs.model.PermitState.permit

任何帮助将不胜感激!

更新只是为了澄清,数据库只有 5 个字段 - OID、PERMITID、INVOICED、USED 和 ORDERED - 这就是为什么我认为它也尝试插入 Permit 实体。当我们使用 Java 7、Spring 3、hibernate-annotations 3.3.1.GA 和 hibernate-entitymanager 3.3.2.GA 时,完全相同的代码无需修改即可工作。我们现在使用 Java 8、Spring 4 和 Hibernate core+entitymanager+ehcache 4.2.19。

最佳答案

在我看来,从异常情况来看,您尝试了 @Transient,同时仍然拥有 @OneToOne 和 @JoinColumn。这实际上没有意义,因为你告诉 Hibernate 你想自己处理它并且它也应该处理它。

此外,我发现有点令人困惑,您在 PermitState 中拥有 Permit 实体和 PermitId。你告诉它你不想更新permitId,但你仍然使用它作为连接列?

我建议删除 PermitId,并在 PermitState 中仅包含 Permit 实体。如果您愿意,您仍然可以使用 getPermitId 方法,但将其视为聚合。

如果所有其他方法都失败,请尝试记录 Hibernate 生成的 SQL 以查看发生了什么。也许贴出来给我们看看。

关于java - 持久化实体时出现 SQLServerException - 索引超出范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31454515/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com