Java 使用MySql在Hibernate中获取lazyLoadException

Java 使用MySql在Hibernate中获取lazyLoadException,java,mysql,hibernate,jpa,Java,Mysql,Hibernate,Jpa,我对lazyLoadException有意见 我已经在谷歌上搜索过了,但这些东西都不起作用 我的配置文件 hibernate.connection.driver_class=com.mysql.jdbc.Driver hibernate.connection.username=root hibernate.connection.password=root hibernate.connection.url=jdbc:mysql://localhost:3306/nfehost hibernate.

我对lazyLoadException有意见

我已经在谷歌上搜索过了,但这些东西都不起作用

我的配置文件

hibernate.connection.driver_class=com.mysql.jdbc.Driver
hibernate.connection.username=root
hibernate.connection.password=root
hibernate.connection.url=jdbc:mysql://localhost:3306/nfehost
hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect
hibernate.show_sql=true
hibernate.format_sql=true
javax.persistence.validation.mode=none
hibernate.jdbc.use_streams_for_binary=true
hibernate.connection.pool_size=1
hibernate.cache.provider_class=org.hibernate.cache.internal.NoCacheProvider
current_session_context_class=org.hibernate.context.internal.ThreadLocalSessionContext
hibernate.current_session_context_class=thread
hibernate.c3p0.min_size=5
hibernate.c3p0.max_size=20
hibernate.c3p0.max_statements=50
hibernate.c3p0.timeout=1800
我的openSessionViewFilter类

package com.nfehost.view.filter;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebFilter;

import org.hibernate.Session;
import org.hibernate.Transaction;

import com.nfehost.dao.HibernateSessionFactory;
import com.nfehost.util.NullUtil;

@WebFilter(urlPatterns="/*")
public class OpenSessionInViewFilter implements Filter {

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {

        Transaction transaction = null;

        try {

            Session session = HibernateSessionFactory.getSession();
            transaction = session.beginTransaction();
            chain.doFilter(request, response);
            transaction.commit();

        } finally {

            if (NullUtil.isNull(transaction) && transaction.isActive()) {
                transaction.rollback();
            }
        }


    }

    @Override
    public void init(FilterConfig arg0) throws ServletException {

    }   

    @Override
    public void destroy() {
    }
}
my web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns="http://java.sun.com/xml/ns/javaee"
        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
        version="3.0">

    <display-name>nfehost</display-name>
    <welcome-file-list>
      <welcome-file>login.xhtml</welcome-file>
    </welcome-file-list>

    <!-- timeout sessao -->
     <session-config>
       <session-timeout>30</session-timeout>
     </session-config>

     <servlet>
       <servlet-name>Faces Servlet</servlet-name>
       <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
       <load-on-startup>1</load-on-startup>
     </servlet>

     <servlet-mapping>
       <servlet-name>Faces Servlet</servlet-name>
       <url-pattern>*.xhtml</url-pattern>
     </servlet-mapping>

     <context-param>
       <param-name>javax.faces.DATETIMECONVERTER_DEFAULT_TIMEZONE_IS_SYSTEM_TIMEZONE</param-name>
       <param-value>true</param-value>
     </context-param>

     <listener>
        <listener-class>com.nfehost.framework.CoerceToZeroListener</listener-class>
     </listener>

     <listener>
        <listener-class>com.nfehost.framework.EmailTimerListener</listener-class>
     </listener>    

     <context-param>
       <param-name>javax.faces.FACELETS_SKIP_COMMENTS</param-name>
       <param-value>true</param-value>
     </context-param>

     <servlet>
       <servlet-name>DispatcherServlet</servlet-name>
       <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
       <init-param>
         <param-name>contextConfigLocation</param-name>
         <param-value>/WEB-INF/classes/resource/spring/spring-servlet.xml</param-value>
       </init-param>
       <load-on-startup>1</load-on-startup>
     </servlet>

     <listener>
       <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
     </listener>

     <context-param>
       <param-name>contextConfigLocation</param-name>
       <param-value>/WEB-INF/classes/resource/spring/spring-*.xml</param-value>
     </context-param>

    <filter>
      <filter-name>PrimeFaces FileUpload Filter</filter-name>
      <filter-class>org.primefaces.webapp.filter.FileUploadFilter</filter-class>
    </filter>

    <filter-mapping>
      <filter-name>PrimeFaces FileUpload Filter</filter-name>
      <servlet-name>Faces Servlet</servlet-name>
    </filter-mapping>

    <error-page>
      <exception-type>java.lang.Throwable</exception-type >
      <location>/pageError.xhtml</location>
    </error-page>

</web-app>
我不知道该做什么,因为我的模型类中没有任何@oneToMany关系或@manyToMany关系

@EqualsAndHashCode(callSuper = false)
@Data
@Entity
@Table(name = "arquivo_nota_fiscal")
public class Arquivo extends Persistent {

    private static final long serialVersionUID = -3255362119912486510L;

    @Size(max = 45)
    @Column(name = "nome")
    private String nome;

    @Temporal(TemporalType.DATE)
    @Column(name = "data_registro", updatable = false)
    private Date dataRegistro;

    @Lob
    //@Basic(fetch = FetchType.LAZY)
    @Column(name = "conteudo", columnDefinition = "longtext")
    private String conteudo;

}
阿奎沃级

我使用lombok,因为它没有getter和setter

不动产

@EqualsAndHashCode(callSuper = false, exclude = {"arquivoNotaFiscal","emitente","destinatario"})
@Data
@Entity
@Table(name = "nota_fiscal")
public class NotaFiscal extends Persistent {

    private static final long serialVersionUID = -7632933705216815478L;

    public enum TipoOperacao {

        ENTRADA(0, "Entrada"), 
        SAIDA(1, "Saída");

        @Getter
        private final int index;
        @Getter 
        private final String descricao;

        private TipoOperacao(int index, String descricao) {
            this.index = index;
            this.descricao = descricao;
        }

        public static TipoOperacao valueOf(int index) {
            for(TipoOperacao tipoOperacao : TipoOperacao.values()) {
                if (tipoOperacao.index == index) {
                    return tipoOperacao;
                }
            }
            return null;
        }
    }

    public enum TipoEmissao {

        NORMAL(1, "Normal - emissão normal"), 
        FS(2, "Contingência FS - emissão em contingência com impressão do DANFE em Formulário de Segurança"), 
        SCAN(3, "Contingência SCAN - emissão em contingência no Sistema de Contingência do Ambiente Nacional - SCAN"), 
        DPEC(4,"Contingência DPEC - emissão em contingência com envio da Declaração Prévia de Emissão em Contingência - DPEC"), 
        FS_DA(5, "Contingência FS-DA - emissão em contingência com impressão do DANFE em Formulário de Segurança para Impressão de Documento Auxiliar de Documento Fiscal");

        @Getter
        private final int index;
        @Getter 
        private final String descricao;

        private TipoEmissao(int index, String descricao) {
            this.index = index;
            this.descricao = descricao;
        }

        public static TipoEmissao valueOf(int index) {
            for(TipoEmissao tipoEmissao : TipoEmissao.values()) {
                if (tipoEmissao.index == index) {
                    return tipoEmissao;
                }
            }
            return null;
        }
    }

    public enum FinalidadeEmissao {

        NORMAL(1, "NF-e normal"), 
        AJUSTE(2, "NF-e complementar"), 
        COMPLEMENTAR(3, "NF-e de ajuste");

        @Getter 
        private int index;
        @Getter 
        private final String descricao;

        private FinalidadeEmissao(int index, String descricao) {
            this.index = index;
            this.descricao = descricao;
        }

        public static FinalidadeEmissao valueOf(int index) {
            for(FinalidadeEmissao finalidadeEmissao : FinalidadeEmissao.values()) {
                if (finalidadeEmissao.index == index) {
                    return finalidadeEmissao;
                }
            }
            return null;
        }
    }

    public enum IdentificadorProcessoEmissao {

        APLICATIVO_CONTRIBUINTE(0, "Emissão de NF-e com aplicativo do contribuinte"), 
        AVULSA_FISCO(1, "Emissão de NF-e avulsa pelo Fisco"), 
        AVULSA_CONTRIBUINTE(2, "Emissão de NF-e avulsa, pelo contribuinte com seu certificado digital, através do site do Fisco"), 
        CONTRIBUINTE_FISCO(3, "Emissão NF-e pelo contribuinte com aplicativo fornecido pelo Fisco");

        @Getter 
        private final int index;
        @Getter 
        private final String descricao;

        private IdentificadorProcessoEmissao(int index, String descricao) {
            this.index = index;
            this.descricao = descricao;
        }

        public static IdentificadorProcessoEmissao valueOf(int index) {
            for(IdentificadorProcessoEmissao identificadorProcessoEmissao : IdentificadorProcessoEmissao.values()) {
                if (identificadorProcessoEmissao.index == index) {
                    return identificadorProcessoEmissao;
                }
            }
            return null;
        }
    }

    @Size(max = 60)
    @Column(name = "descricao_natureza_operacao")
    private String descricaoNaturezaOperacao;

    @NotNull
    @Column(name = "serie")
    private Integer serie;

    @NotNull
    @Column(name = "numero")
    private Integer numero;

    @Temporal(TemporalType.DATE)
    @Column(name = "data_emissao")
    private Date dataEmissao;

    @Temporal(TemporalType.DATE)
    @Column(name = "data_hora_entrada_ou_saida_produto")
    private Date dataHoraEntradaOuSaidaProduto;

    @Type(type = TipoOperacaoType.TYPE)
    @Column(name = "tipo_operacao", columnDefinition = "int", length = 1)
    private TipoOperacao tipoOperacao;

    @Type(type = TipoEmissaoType.TYPE)
    @Column(name = "tipo_emissao", columnDefinition = "int", length = 1)
    private TipoEmissao tipoEmissao;

    @Type(type = FinalidadeEmissaoType.TYPE)
    @Column(name = "finalidade_emissao", columnDefinition = "int", length = 1)
    private FinalidadeEmissao finalidadeEmissao;

    @Type(type = IdentificadorProcessoEmissaoType.TYPE)
    @Column(name = "identificador_processo_emissao", columnDefinition = "int", length = 1)
    private IdentificadorProcessoEmissao identificadorProcessoEmissao;

    @NotNull
    @Column(name = "valor_icms")
    private BigDecimal valorIcms;

    @NotNull
    @Column(name = "valor_nota_fiscal")
    private BigDecimal valorNotaFiscal;

    @NotNull
    @Column(name = "chave_nfe", length = 44)
    private String chaveNfe;

    @Size(max = 28)
    @Column(name = "digest_value")
    private String digestValue;

    @ManyToOne(cascade = CascadeType.ALL)
    @JoinColumn(name = "emitente_id", referencedColumnName = "id")
    private Emitente emitente;

    @ManyToOne(cascade = CascadeType.ALL)
    @JoinColumn(name = "destinatario_id", referencedColumnName = "id")
    private Destinatario destinatario;

    @OneToOne(cascade = CascadeType.ALL, fetch = FetchType.LAZY)
    @JoinColumn(name = "arquivo_nota_fiscal_id", referencedColumnName = "id")
    private Arquivo arquivoNotaFiscal;

}

你对阿奎沃很懒惰。您正在尝试在非会话上下文中获取。你可以把它改成渴望


或者在获取notaFinancial后执行Hibernate.initialize(notaFinancial.getarquivonotaFinancial())

问题在下面的Arquivo类代码中

@Lob //@基本(fetch=FetchType.LAZY) @列(name=“conteudo”,columnDefinition=“longtext”) 私有字符串上下文

上面显示的列用@Lob标记。用此批注标记的列的默认获取模式为惰性。根据堆栈跟踪,调用toString()方法。toString()方法试图访问所有字段,并获取“conteudo”字段的延迟异常

org.hibernate.proxy.pojo.javassist.javassistlazinitializer.invoke(javassistlazinitializer.java:185)位于com.nfehost.model.Arquivo\u$$\ ujavassist\u3.toString(Arquivo\u$\ ujavassist\u3.java)

解决方案:
您应该更改该列的获取模式,或者在不使用该列的情况下定义toString()方法。

是否可以粘贴实体Arquivo_uuu?Persistent有什么?可能有到Arquivo的映射?从日志中。是的……我要把它放进去……我有一个字段,
conteudo
,它非常大……它是一个长字符串,可以让它懒惰还是不懒惰?是的,你可以在字符串属性conteudo上添加懒惰。这也应该起作用。让阿基沃诺塔感到兴奋。但同样,如果您将conteudo设置为懒惰,您可能无法在outofsession上下文中获取它,您可能会再次遇到此问题。好的……但我在internet上阅读了有关此问题的文章,openSessionViewFilter模式将因此问题停止……但不要停止为什么重新定义toString()方法?
@EqualsAndHashCode(callSuper = false, exclude = {"arquivoNotaFiscal","emitente","destinatario"})
@Data
@Entity
@Table(name = "nota_fiscal")
public class NotaFiscal extends Persistent {

    private static final long serialVersionUID = -7632933705216815478L;

    public enum TipoOperacao {

        ENTRADA(0, "Entrada"), 
        SAIDA(1, "Saída");

        @Getter
        private final int index;
        @Getter 
        private final String descricao;

        private TipoOperacao(int index, String descricao) {
            this.index = index;
            this.descricao = descricao;
        }

        public static TipoOperacao valueOf(int index) {
            for(TipoOperacao tipoOperacao : TipoOperacao.values()) {
                if (tipoOperacao.index == index) {
                    return tipoOperacao;
                }
            }
            return null;
        }
    }

    public enum TipoEmissao {

        NORMAL(1, "Normal - emissão normal"), 
        FS(2, "Contingência FS - emissão em contingência com impressão do DANFE em Formulário de Segurança"), 
        SCAN(3, "Contingência SCAN - emissão em contingência no Sistema de Contingência do Ambiente Nacional - SCAN"), 
        DPEC(4,"Contingência DPEC - emissão em contingência com envio da Declaração Prévia de Emissão em Contingência - DPEC"), 
        FS_DA(5, "Contingência FS-DA - emissão em contingência com impressão do DANFE em Formulário de Segurança para Impressão de Documento Auxiliar de Documento Fiscal");

        @Getter
        private final int index;
        @Getter 
        private final String descricao;

        private TipoEmissao(int index, String descricao) {
            this.index = index;
            this.descricao = descricao;
        }

        public static TipoEmissao valueOf(int index) {
            for(TipoEmissao tipoEmissao : TipoEmissao.values()) {
                if (tipoEmissao.index == index) {
                    return tipoEmissao;
                }
            }
            return null;
        }
    }

    public enum FinalidadeEmissao {

        NORMAL(1, "NF-e normal"), 
        AJUSTE(2, "NF-e complementar"), 
        COMPLEMENTAR(3, "NF-e de ajuste");

        @Getter 
        private int index;
        @Getter 
        private final String descricao;

        private FinalidadeEmissao(int index, String descricao) {
            this.index = index;
            this.descricao = descricao;
        }

        public static FinalidadeEmissao valueOf(int index) {
            for(FinalidadeEmissao finalidadeEmissao : FinalidadeEmissao.values()) {
                if (finalidadeEmissao.index == index) {
                    return finalidadeEmissao;
                }
            }
            return null;
        }
    }

    public enum IdentificadorProcessoEmissao {

        APLICATIVO_CONTRIBUINTE(0, "Emissão de NF-e com aplicativo do contribuinte"), 
        AVULSA_FISCO(1, "Emissão de NF-e avulsa pelo Fisco"), 
        AVULSA_CONTRIBUINTE(2, "Emissão de NF-e avulsa, pelo contribuinte com seu certificado digital, através do site do Fisco"), 
        CONTRIBUINTE_FISCO(3, "Emissão NF-e pelo contribuinte com aplicativo fornecido pelo Fisco");

        @Getter 
        private final int index;
        @Getter 
        private final String descricao;

        private IdentificadorProcessoEmissao(int index, String descricao) {
            this.index = index;
            this.descricao = descricao;
        }

        public static IdentificadorProcessoEmissao valueOf(int index) {
            for(IdentificadorProcessoEmissao identificadorProcessoEmissao : IdentificadorProcessoEmissao.values()) {
                if (identificadorProcessoEmissao.index == index) {
                    return identificadorProcessoEmissao;
                }
            }
            return null;
        }
    }

    @Size(max = 60)
    @Column(name = "descricao_natureza_operacao")
    private String descricaoNaturezaOperacao;

    @NotNull
    @Column(name = "serie")
    private Integer serie;

    @NotNull
    @Column(name = "numero")
    private Integer numero;

    @Temporal(TemporalType.DATE)
    @Column(name = "data_emissao")
    private Date dataEmissao;

    @Temporal(TemporalType.DATE)
    @Column(name = "data_hora_entrada_ou_saida_produto")
    private Date dataHoraEntradaOuSaidaProduto;

    @Type(type = TipoOperacaoType.TYPE)
    @Column(name = "tipo_operacao", columnDefinition = "int", length = 1)
    private TipoOperacao tipoOperacao;

    @Type(type = TipoEmissaoType.TYPE)
    @Column(name = "tipo_emissao", columnDefinition = "int", length = 1)
    private TipoEmissao tipoEmissao;

    @Type(type = FinalidadeEmissaoType.TYPE)
    @Column(name = "finalidade_emissao", columnDefinition = "int", length = 1)
    private FinalidadeEmissao finalidadeEmissao;

    @Type(type = IdentificadorProcessoEmissaoType.TYPE)
    @Column(name = "identificador_processo_emissao", columnDefinition = "int", length = 1)
    private IdentificadorProcessoEmissao identificadorProcessoEmissao;

    @NotNull
    @Column(name = "valor_icms")
    private BigDecimal valorIcms;

    @NotNull
    @Column(name = "valor_nota_fiscal")
    private BigDecimal valorNotaFiscal;

    @NotNull
    @Column(name = "chave_nfe", length = 44)
    private String chaveNfe;

    @Size(max = 28)
    @Column(name = "digest_value")
    private String digestValue;

    @ManyToOne(cascade = CascadeType.ALL)
    @JoinColumn(name = "emitente_id", referencedColumnName = "id")
    private Emitente emitente;

    @ManyToOne(cascade = CascadeType.ALL)
    @JoinColumn(name = "destinatario_id", referencedColumnName = "id")
    private Destinatario destinatario;

    @OneToOne(cascade = CascadeType.ALL, fetch = FetchType.LAZY)
    @JoinColumn(name = "arquivo_nota_fiscal_id", referencedColumnName = "id")
    private Arquivo arquivoNotaFiscal;

}