java - Hibernate S1093 或 07009 参数索引无效

标签 java sql-server hibernate jpa jdbc

我正在使用 Hibernate 4.3、Java 8 和 Microsoft SQL 2014 (MSSQL)。

我正在尝试使用 Hibernate 进行实体的 merge()。

public void actualizar(FactorUnidadMedida obj){
    EntityManagerFactory entityManagerFactory = HibernateUtil.getEntityManagerFactory();
    EntityManager em = entityManagerFactory.createEntityManager();
    em.getTransaction().begin();
    em.merge(obj);
    em.getTransaction().commit();
}

当 hibernate 尝试执行 commit() 时,我收到以下错误:

参数索引 8 无效。

我尝试了不同版本的 Hibernate(4.3、5.0)和 JDBC 驱动程序(sqljdbc4.jar、jTDS.jar)。

这是日志:

2016-07-20 15:09:35 Hibernate: update FactorUnidadMedida set estado=?, factor=?, fecha=?, usuario=? where idEmpresa=? and codUnidadDestino=? and codUnidadOrigen=?

2016-07-20 15:09:35 TRACE BasicBinder:65 - binding parameter [1] as [VARCHAR] - [AC]

2016-07-20 15:09:35 TRACE BasicBinder:65 - binding parameter [2] as [NUMERIC] - [0.01]

2016-07-20 15:09:35 TRACE BasicBinder:65 - binding parameter [3] as [TIMESTAMP] - [Wed Jul 20 15:09:25 COT 2016]

2016-07-20 15:09:35 TRACE BasicBinder:65 - binding parameter [4] as [VARCHAR] - [ADMIN]

2016-07-20 15:09:35 TRACE BasicBinder:65 - binding parameter [5] as [INTEGER] - [1]

2016-07-20 15:09:35 TRACE BasicBinder:65 - binding parameter [6] as [VARCHAR] - [MTR]

2016-07-20 15:09:35 TRACE BasicBinder:65 - binding parameter [7] as [INTEGER] - [1]

2016-07-20 15:09:35 TRACE BasicBinder:65 - binding parameter [8] as [VARCHAR] - [CMS]

2016-07-20 15:09:35 INFO AbstractBatchImpl:193 - HHH000010: On release of batch it still contained JDBC statements

2016-07-20 15:09:35 WARN SqlExceptionHelper:127 - SQL Error: 0, SQLState: 07009

2016-07-20 15:09:35 ERROR SqlExceptionHelper:129 - Invalid parameter index 8.

其他信息:

该实体有两个复合外键。

package co.com.hermesWeb.model;

import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;

import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.IdClass;
import javax.persistence.JoinColumn;
import javax.persistence.JoinColumns;
import javax.persistence.OneToOne;
import javax.persistence.Table;

@Entity
@Table(name="FactorUnidadMedida")
@IdClass(FactorUnidadMedidaPK.class)
public class FactorUnidadMedida implements Serializable {
    private static final long serialVersionUID = -4123771692139896513L;

    @Id
    private int idEmpresa = 0;
    @Id
    @OneToOne(fetch=FetchType.EAGER)
    @JoinColumns({
        @JoinColumn(name="idEmpresa", referencedColumnName="idEmpresa", insertable=false, updatable=false),
        @JoinColumn(name="codUnidadOrigen", referencedColumnName="codigo", insertable=false, updatable=false)
    })
    private UnidadMedida unidadMedidaOrigen = null; 
    @Id
    @OneToOne(fetch=FetchType.EAGER)
    @JoinColumns({
        @JoinColumn(name="idEmpresa", referencedColumnName="idEmpresa", insertable=false, updatable=false),
        @JoinColumn(name="codUnidadDestino", referencedColumnName="codigo", insertable=false, updatable=false)
    })
    private UnidadMedida unidadMedidaDestino = null;
    private BigDecimal factor = BigDecimal.ZERO;
    private String estado = "";
    private String usuario = "";
    private Date fecha = null;

    public int getIdEmpresa() {
        return idEmpresa;
    }
    public void setIdEmpresa(int idEmpresa) {
        this.idEmpresa = idEmpresa;
    }
    public UnidadMedida getUnidadMedidaOrigen() {
        return unidadMedidaOrigen;
    }
    public void setUnidadMedidaOrigen(UnidadMedida unidadMedidaOrigen) {
        this.unidadMedidaOrigen = unidadMedidaOrigen;
    }
    public UnidadMedida getUnidadMedidaDestino() {
        return unidadMedidaDestino;
    }
    public void setUnidadMedidaDestino(UnidadMedida unidadMedidaDestino) {
        this.unidadMedidaDestino = unidadMedidaDestino;
    }
    public BigDecimal getFactor() {
        return factor;
    }
    public void setFactor(BigDecimal factor) {
        this.factor = factor;
    }
    public String getEstado() {
        return estado;
    }
    public void setEstado(String estado) {
        this.estado = estado;
    }
    public String getUsuario() {
        return usuario;
    }
    public void setUsuario(String usuario) {
        this.usuario = usuario;
    }
    public Date getFecha() {
        return fecha;
    }
    public void setFecha(Date fecha) {
        this.fecha = fecha;
    }

}

请注意,[idEmpresa, codUnidadOrigen] 和 [idEmpresa, codUnidadDestino] 是我的外键,它们使用相同的字段 [idEmpresa]。 因为这个原因有一些问题吗?

这是一个数据库表图像: /image/87M6U.jpg

这是完整的堆栈:log4j.logger.org.hibernate=ALL https://gist.github.com/ferchoman09/45df8600de44eebc37a693e53a2bd391

最佳答案

我必须更改模型。我将两个没有@Id 的外键放在单独的字段中。

package co.com.hermesWeb.model;

import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;

import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.IdClass;
import javax.persistence.JoinColumn;
import javax.persistence.JoinColumns;
import javax.persistence.OneToOne;
import javax.persistence.Table;

@Entity
@Table(name="FactorUnidadMedida")
@IdClass(FactorUnidadMedidaPK.class)
public class FactorUnidadMedida implements Serializable {
    private static final long serialVersionUID = -4123771692139896513L;

    @Id
    private int idEmpresa = 0;
    @Id
    private String codUnidadOrigen = "";
    @Id
    private String codUnidadDestino = "";

    @OneToOne(fetch=FetchType.EAGER)
    @JoinColumns({
        @JoinColumn(name="idEmpresa", referencedColumnName="idEmpresa", insertable=false, updatable=false),
        @JoinColumn(name="codUnidadOrigen", referencedColumnName="codigo", insertable=false, updatable=false)
    })
    private UnidadMedida unidadMedidaOrigen = null; 

    @OneToOne(fetch=FetchType.EAGER)
    @JoinColumns({
        @JoinColumn(name="idEmpresa", referencedColumnName="idEmpresa", insertable=false, updatable=false),
        @JoinColumn(name="codUnidadDestino", referencedColumnName="codigo", insertable=false, updatable=false)
    })
    private UnidadMedida unidadMedidaDestino = null;
    private BigDecimal factor = BigDecimal.ZERO;
    private String estado = "";
    private String usuario = "";
    private Date fecha = null;

    public int getIdEmpresa() {
        return idEmpresa;
    }
    public void setIdEmpresa(int idEmpresa) {
        this.idEmpresa = idEmpresa;
    }
    public UnidadMedida getUnidadMedidaOrigen() {
        return unidadMedidaOrigen;
    }
    public UnidadMedida getUnidadMedidaDestino() {
        return unidadMedidaDestino;
    }
    public BigDecimal getFactor() {
        return factor;
    }
    public void setFactor(BigDecimal factor) {
        this.factor = factor;
    }
    public String getEstado() {
        return estado;
    }
    public void setEstado(String estado) {
        this.estado = estado;
    }
    public String getUsuario() {
        return usuario;
    }
    public void setUsuario(String usuario) {
        this.usuario = usuario;
    }
    public Date getFecha() {
        return fecha;
    }
    public void setFecha(Date fecha) {
        this.fecha = fecha;
    }
    public String getCodUnidadOrigen() {
        return codUnidadOrigen;
    }
    public void setCodUnidadOrigen(String codUnidadOrigen) {
        this.codUnidadOrigen = codUnidadOrigen;
    }
    public String getCodUnidadDestino() {
        return codUnidadDestino;
    }
    public void setCodUnidadDestino(String codUnidadDestino) {
        this.codUnidadDestino = codUnidadDestino;
    }

}

关于java - Hibernate S1093 或 07009 参数索引无效,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38490061/

相关文章:

java - Android appcompat v7 错误

sql-server - 如何在 .cfc 文件中的一个 DELETE 语句中从多个表中删除?

java - 如何将 from-subquery 转换为 Hibernate Criteria 语句

java - Hibernate删除了一条记录,但是记录并没有消失?

java - Spring 安全示例

java - 动态形成 SQL 查询

Java:使用 Axis2 stub 类调用 Web 服务

java - 尝试扫描一个整数,然后扫描一个字符串

sql-server - SQL Server 复制测试

sql - 将不同表中的两列连接成一列