2010-09-20 13 views
8

Próbuję zmienić kod JDBC mojej aplikacji WWW na WZP przy użyciu dostawcy Hibernate. Korzystam z IDE Eclipse. W tym punkcie zdefiniowałem źródło danych MySQL. Dodałem go w pliku persistence.xml. Ale otrzymuję poniżej błąd.Jak zdefiniować źródło danych inne niż JTA dla Hibernate JPA? org.hibernate.connection.DatasourceConnectionProvider - Nie można znaleźć źródła danych:

6640 [[email protected]] ERROR org.hibernate.connection.DatasourceConnectionProvider - Could not find datasource: tamSql 
javax.naming.NameNotFoundException; remaining name 'tamSql' 

Moja persistence.xml wygląda,

<?xml version="1.0" encoding="UTF-8"?> 
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"> 
<persistence-unit name="ExpensePersistentUnit" transaction-type="RESOURCE_LOCAL"> 
<provider>org.hibernate.ejb.HibernatePersistence</provider> 
<non-jta-data-source>tamSql</non-jta-data-source> 
    <class>com.pricar.JPAInteg.Role</class> 
    <class>com.pricar.JPAInteg.User</class> 
    <class>com.pricar.JPAInteg.Userdetail</class> 
    <class>com.pricar.JPAInteg.Category</class> 
    <class>com.pricar.JPAInteg.Expens</class> 
    <class>com.pricar.JPAInteg.Leavetable</class> 
    <class>com.pricar.JPAInteg.Permissiontoken</class> 
    <class>com.pricar.JPAInteg.Roletokenassociation</class> 
    <class>com.pricar.JPAInteg.UserPK</class> 
<properties> 
    <property name="hibernate.connection.url" value="jdbc:mysql://localhost/officemgmt"/> 
    <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"></property> 
    <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/> 
    <property name="hibernate.connection.password" value="1234"/> 
    <property name="hibernate.connection.username" value="root"/> 
    <property name="hibernate.hbm2ddl.auto" value="update"/> 
    <property name="hibernate.show_sql" value="true"/> 

</properties> 

Wszelkie sugestie !!! Dzięki z góry!

+0

Czy możesz opublikować kod deklaracji nazwy JNDI. –

+0

@Jaydeep: Możesz mi powiedzieć, co to jest nazwa JNDI i gdzie muszę ją zadeklarować. Jestem bardzo nowy w JPA i Hibernate. Dzięki –

Odpowiedz

24

Nie potrzebujesz <non-jta-data-source>, gdy źródło danych jest skonfigurowane w <properties>. <non-jta-data-source> jest potrzebny, gdy źródło danych jest skonfigurowane w konfiguracji serwera aplikacji i uzyskane przez JNDI.

+1

Ya, masz rację. Dzięki za odpowiedź. Właściwie to nie rozumiem specyfikacji JPA/Hibernate. Byłoby zrozumiałe, gdybyś powiedział mi, że "należy użyć zakresu typu transakcji =" RESOURCE_LOCAL "Z tego powodu dodałem tylko i <źródło danych innych niż jta> –

+4

Różne typy transakcji i' <źródło danych jta > '/' 'ma sens tylko wtedy, gdy używasz pełnego serwera aplikacji (JBoss, WebSphere, WebLogic, itp.) Jeśli masz autonomiczną aplikację lub kontener serwletów (Tomcat, Jetty) , po prostu napisz "transaction-type =" RESOURCE_LOCAL "'. – axtavt

+0

Czy istnieje sposób, abyśmy mogli skonfigurować w Eclipse lub Windows Machine, więc nie potrzebuję używać wielu jednostek trwałości dla lokalny/serwer –

Powiązane problemy