gpt4 book ai didi

java - 使用MySql在Hibernate中获取lazyLoadException

转载 作者:行者123 更新时间:2023-11-29 08:11:30 25 4
gpt4 key购买 nike

我遇到了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() {
}
}

我的 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>

我的堆栈跟踪

Jan 31, 2014 6:01:56 PM com.sun.faces.lifecycle.InvokeApplicationPhase execute
Advertência: could not initialize proxy - no Session
org.hibernate.LazyInitializationException: could not initialize proxy - no Session
at org.hibernate.proxy.AbstractLazyInitializer.initialize(AbstractLazyInitializer.java:164)
at org.hibernate.proxy.AbstractLazyInitializer.getImplementation(AbstractLazyInitializer.java:285)
at org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.invoke(JavassistLazyInitializer.java:185)
at com.nfehost.model.Arquivo_$$_javassist_3.toString(Arquivo_$$_javassist_3.java)
at java.lang.String.valueOf(Unknown Source)
at java.lang.StringBuilder.append(Unknown Source)
at com.nfehost.model.NotaFiscal.toString(NotaFiscal.java:32)
at java.lang.String.valueOf(Unknown Source)
at java.lang.StringBuilder.append(Unknown Source)
at com.nfehost.view.NotaFiscalListBean.toString(NotaFiscalListBean.java:16)
at java.text.MessageFormat.subformat(Unknown Source)
at java.text.MessageFormat.format(Unknown Source)
at org.apache.el.util.MessageFactory.get(MessageFactory.java:46)
at org.apache.el.util.ReflectionUtil.getMethod(ReflectionUtil.java:245)
at org.apache.el.parser.AstValue.invoke(AstValue.java:271)
at org.apache.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:274)
at com.sun.faces.facelets.el.TagMethodExpression.invoke(TagMethodExpression.java:105)
at javax.faces.event.MethodExpressionActionListener.processAction(MethodExpressionActionListener.java:147)
at javax.faces.event.ActionEvent.processListener(ActionEvent.java:88)
at javax.faces.component.UIComponentBase.broadcast(UIComponentBase.java:818)
at javax.faces.component.UICommand.broadcast(UICommand.java:300)
at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:790)
at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1282)
at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81)
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:646)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.primefaces.webapp.filter.FileUploadFilter.doFilter(FileUploadFilter.java:70)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at com.nfehost.view.filter.OpenSessionInViewFilter.doFilter(OpenSessionInViewFilter.java:31)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1041)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:603)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)

我不知道该怎么做,因为我的模型类中没有任何 @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;

}

Arquivo.class

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

NotaFiscal.class

@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;

}

最佳答案

你对阿奎沃很懒。您正在尝试在非 session 上下文中获取。您可以将其更改为 EAGER。

或者在获取 NotaFiscal 后执行 Hibernate.initialize(notaFiscal.getArquivoNotaFiscal());

关于java - 使用MySql在Hibernate中获取lazyLoadException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21489074/

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