IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Hibernate Java Discussion :

Mes requêtes nommées ne sont pas trouvées dans mon war


Sujet :

Hibernate Java

  1. #1
    Membre actif Avatar de ploxien
    Inscrit en
    Février 2006
    Messages
    467
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Février 2006
    Messages : 467
    Points : 221
    Points
    221
    Par défaut Mes requêtes nommées ne sont pas trouvées dans mon war
    Hello,

    J'ai des problèmes avec mes requetes nommées.

    Je m'explique. J'ai un projet maven "persistence_layer" qui, comme son nom l'indique, s'occupe de la persistance.

    J'ai un fichier de config hibernate (hibernate.cfg.xml):


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
    <hibernate-configuration>
    	<session-factory>
    		<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
     
    		<property name="hibernate.connection.password">...</property>
    		<property name="hibernate.connection.url">jdbc:mysql://...:3306/i...</property>
     
    		<property name="hibernate.connection.username">...</property>
    		<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
    		<mapping class=...
    		...
    		<mapping resource="namedQueries.hbm.xml" />
    	</session-factory>
     
     
    </hibernate-configuration>
    A côté, j'ai le fichier "namedQueries.hbm.xml", dans le même répertoire (répertoire resources de maven):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    <?xml version='1.0' encoding='utf-8'?>
    <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
     
    <hibernate-mapping>
     
    	<query name="FraudMsg.containsKeywords.temp"><![CDATA[
    		from BodyInfo
    	]]></query>
     
    </hibernate-mapping>
    Ensuite, j'ai deux projets qui utilisent ce projet en tant que dépendance maven, de la même manière que voici:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Query q = session2.getNamedQuery("FraudMsg.containsKeywords.temp");
    List<ch.iict.iscia.persistance.Email> emails = q.list();
    Un, je le dépoye en jar, et aucun problème. Le résultat de la requête est correct

    L'autre, en war sur tomcat, et là, c'est le drame... Il ne trouve pas mes requêtes nommées!
    L'erreur:
    GRAVE: Named query not known: FraudMsg.containsKeywords.temp
    org.hibernate.MappingException: Named query not known: FraudMsg.containsKeywords.temp
    at org.hibernate.impl.AbstractSessionImpl.getNamedQuery(AbstractSessionImpl.java:70)
    at org.hibernate.impl.SessionImpl.getNamedQuery(SessionImpl.java:1260)
    at ch.iict.iscia.cicia.FraudMessageWithKeywordServiceImpl.fraudMessageWithKeyword(FraudMessageWithKeywordServiceImpl.java:45)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at com.sun.xml.ws.api.server.InstanceResolver$1.invoke(InstanceResolver.java:246)
    at com.sun.xml.ws.server.InvokerTube$2.invoke(InvokerTube.java:146)
    at com.sun.xml.ws.server.sei.EndpointMethodHandler.invoke(EndpointMethodHandler.java:257)
    at com.sun.xml.ws.server.sei.SEIInvokerTube.processRequest(SEIInvokerTube.java:93)
    at com.sun.xml.ws.api.pipe.Fiber.__doRun(Fiber.java:598)
    at com.sun.xml.ws.api.pipe.Fiber._doRun(Fiber.java:557)
    at com.sun.xml.ws.api.pipe.Fiber.doRun(Fiber.java:542)
    at com.sun.xml.ws.api.pipe.Fiber.runSync(Fiber.java:439)
    at com.sun.xml.ws.server.WSEndpointImpl$2.process(WSEndpointImpl.java:243)
    at com.sun.xml.ws.transport.http.HttpAdapter$HttpToolkit.handle(HttpAdapter.java:444)
    at com.sun.xml.ws.transport.http.HttpAdapter.handle(HttpAdapter.java:244)
    at com.sun.xml.ws.transport.http.servlet.ServletAdapter.handle(ServletAdapter.java:135)
    at com.sun.xml.ws.transport.http.servlet.WSServletDelegate.doGet(WSServletDelegate.java:129)
    at com.sun.xml.ws.transport.http.servlet.WSServletDelegate.doPost(WSServletDelegate.java:160)
    at com.sun.xml.ws.transport.http.servlet.WSServlet.doPost(WSServlet.java:75)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:263)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:584)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
    at java.lang.Thread.run(Thread.java:619)

  2. #2
    Membre à l'essai
    Inscrit en
    Février 2007
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Février 2007
    Messages : 17
    Points : 14
    Points
    14
    Par défaut
    J'ai exactement le même problème, et je n'ai toujours pas trouvé de solution ...

    Par contre je n'avais pas pensé à tester en déployant sur un JAR ... étrange que cela fonctionne chez toi ! Je vais tenter de tester ça ...

    Je me réjouis de voir si quelqu'un parviendra à mettre le doigts sur le problème ... c'est quand même douteux.

Discussions similaires

  1. Réponses: 2
    Dernier message: 09/09/2014, 14h01
  2. Réponses: 6
    Dernier message: 22/10/2012, 23h11
  3. Réponses: 3
    Dernier message: 23/08/2010, 11h02
  4. Réponses: 1
    Dernier message: 16/05/2007, 15h52

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo