1

Hibernate Entity Manager を使用しています。永続化プロバイダーが見つからないと不平を言いますが、それでもログに記録します:

    TRACE 2011-02-21 22:17:52,843 [main](Ejb3Configuration.java:321) org.hibernate.ejb.Ejb3Configuration - PersistenceMetadata(version=2.0) [
        name: sample
        jtaDataSource: null
        nonJtaDataSource: null
        transactionType: RESOURCE_LOCAL
        provider: org.hibernate.ejb.HibernatePeristence
        useQuotedIdentifiers: false
        classes[
        ]
        packages[
        ]
        mappingFiles[
        ]
        jarFiles[
        ]
        hbmfiles: 0
        properties[
            hibernate.connection.username: scott
            hibernate.connection.password: tiger
            hibernate.dialect: org.hibernate.dialect.OracleDialect
            hibernate.show_sql: true
            hibernate.connection.url: jdbc:oracle:thin:@localhost:1521:krsna
            hibernate.archive.autodetection: class, hbm
            hibernate.connection.driver_class: oracle.jdbc.driver.OracleDriver
        ]]
    Exception in thread "main" javax.persistence.PersistenceException: No Persistence provider for EntityManager named sample
        at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:54)
        at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:32)
        at EMPersistDemo2.main(EMPersistDemo2.java:26)

それを見つけてログに記録することは明らかですが、それでも例外がスローされます。何か不足していますか?

私はmavenを使用しており、src/main/resources/META-INFにpersistence.xmlを配置しました。その内容は次のとおりです。

    <!-- persistence.xml -->
    <persistence ...>
       <persistence-unit name="sample">
        <provider>org.hibernate.ejb.HibernatePeristence</provider>
        <!-- Scan for annotated classes and Hibernate mapping XML files -->
        <properties>
           <property name="hibernate.archive.autodetection" value="class, hbm"/>
           <property name="hibernate.connection.driver_class" value="oracle.jdbc.driver.OracleDriver"/>
           <property name="hibernate.connection.url" value="jdbc:oracle:thin:@localhost:1521:krsna"/>
           <property name="hibernate.connection.username" value="scott"/>
           <property name="hibernate.connection.password" value="tiger"/>
           <property name="hibernate.dialect" value="org.hibernate.dialect.OracleDialect"/>
           <property name="hibernate.show_sql" value="true"/>
        </properties>
        </persistence-unit>

    </persistence>

org.hibernate.Ejb3Configuration はそれを見つけることができます javax.persitence.Persistence はそれを見つけることができません:

EntityManagerFactory emf = Persistence.createEntityManagerFactory("sample");
4

3 に答える 3

2

Java coderanch に関する私の質問に対する答えを見つけました。

の永続化プロバイダの名前にタイプミスがありますpersistence.xml:

に改名org.hibernate.ejb.HibernatePeristenceしました

org.hibernate.ejb.HibernatePersistence
                              ^---

そしてそれは働き始めました。

これが他の人に役立つように、私は自分の答えを投稿しています。

于 2011-02-26T23:27:44.290 に答える
0

エラーメッセージに「永続化プロバイダーが見つかりません」と表示されるため、休止状態のjarファイルがクラスパスにないようなにおいがします

于 2011-02-22T07:00:54.680 に答える