Configurando o Hibernate para HQL
-
21-12-2019 - |
Pergunta
Estou recebendo o seguinte erro na consulta mais simples:
org.hibernate.hql.internal.ast.QuerySyntaxException: <table_name> is not mapped [<query_string>]
Em hibernate.cfg.xml
Eu tenho a propriedade;
<property name="current_session_context_class">org.hibernate.context.internal.ThreadLocalSessionContext</property>
ThreadLocalSessionContext
é em org.hibernate.context.internal
de Hibernate 4.x-hibernate-core-4.2.6.Final.jar
.
Todo o resto no Hibernate está funcionando bem.Contudo Não estou conseguindo executar uma consulta.
O que estou perdendo?
Obrigado pela ajuda.
//=========================
EDITAR:
<table_name>
é definido como uma entidade em hibernate.cfg.xml
e tudo mas HQL-- incluindo as atualizações em <table_name>
estão trabalhando sem erros.
Solução
Existem duas possibilidades que me vêm à mente
O nome que você está se referindo no seu HQL não é uma Entidade.Por exemplo,
HQL é "Select testEntity from TestEntity testEntity", porém não há nenhuma classe de entidade chamada TestEntity definida
ou
Você definiu TestEntity, mas ele não é gerenciado.Você diz que outra operação na entidade está funcionando, parece que provavelmente você está usando o nome errado no seu HQL.No entanto, se quiser ter certeza de que a entidade é gerenciada, você pode ativar o log de depuração do Hibernate e deverá ver informações como as abaixo, nas quais você pode ver a lista de classes gerenciadas.
01:09:40,322 DEBUG HibernatePersistenceProvider:110 - Checking persistence-unit [name=persistence-unit_test, explicit-provider=org.hibernate.ejb.HibernatePersistence] against incoming persistence unit name [persistence-unit_demo] 01:09:40,322 DEBUG ProviderChecker:106 - Persistence-unit [persistence-unit_demo] requested PersistenceProvider [org.hibernate.ejb.HibernatePersistence] 01:09:40,322 DEBUG LogHelper:117 - PersistenceUnitInfo [ name: persistence-unit_demo persistence provider classname: org.hibernate.ejb.HibernatePersistence classloader: null excludeUnlistedClasses: false JTA datasource: null Non JTA datasource: null Transaction type: RESOURCE_LOCAL PU root URL: file:/E:/Test/target/classes/ Shared Cache Mode: null Validation Mode: null Jar files URLs [] Managed classes names [ com.test.model.TestEntity Mapping files names [] Properties [ hibernate.c3p0.timeout: 100 hibernate.connection.autocommit: false hibernate.connection.driver_class: com.mysql.jdbc.Driver hibernate.c3p0.max_statements: 0 hibernate.c3p0.max_size: 50 hibernate.dialect: org.hibernate.dialect.MySQL5InnoDBDialect hibernate.c3p0.idle_test_period: 100 hibernate.c3p0.min_size: 5 hibernate.connection.username: XXXX hibernate.hbm2ddl.auto: update hibernate.c3p0.acquire_increment: 5 hibernate.connection.url: jdbc:mysql://localhost:3306/test hibernate.connection.password: XXXX hibernate.show_sql: true hibernate.connection.provider_class: org.hibernate.connection.C3P0ConnectionProvider] 01:09:40,337 DEBUG IntegratorServiceImpl:63 - Adding Integrator [org.hibernate.cfg.beanvalidation.BeanValidationIntegrator]. 01:09:40,353 DEBUG IntegratorServiceImpl:63 - Adding Integrator [org.hibernate.secure.spi.JaccIntegrator].
Outras dicas
O erro deve vir principalmente do query itself
.você deve tentar certificar-se de que o nome do Entity
você está executando uma solicitação é exatamente igual ao nome do class
não gosto do nome do SQL table
associado a ele.