2

Oracle 11g で Hibernate 4.2 を使用しようとしています。以下は私のhibernate.cfg.xmlファイルです:

<?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 name="sessionFactory">
<property name="hibernate.connection.driver_class">oracle.jdbc.OracleDriver</property>
<property name="hibernate.connection.password">abcde@1234</property>
<property     name="hibernate.connection.url">    
jdbc:oracle:thin:ourhost:1521:oursid</property>
<property name="hibernate.connection.username">OURUSER</property>
<property name="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</property>

<mapping resource="resources/mapping/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>

そして、セッション ファクトリを取得するための私の util クラスは次のとおりです。

public class HibernateUtil {

private SessionFactory sessionFactory;

public HibernateUtil() {
    sessionFactory = createSessionFactory();
}

private static SessionFactory createSessionFactory() {
      SessionFactory factory = null;
    try {
         Configuration configuration = new Configuration();
         configuration.configure("resources/hibernate.cfg.xml");
         factory = configuration.buildSessionFactory();        
    } catch (Throwable ex) {

        System.err.println("Initial SessionFactory creation failed.");
        ex.printStackTrace();
        throw new ExceptionInInitializerError(ex);

    }
    return factory;

}

public  SessionFactory  getSessionFactory(){
    return this.sessionFactory;
}
}

mysql データベースと関連する hibernate.cfg.xml を使用する場合、これは正常に機能します。上記のようにOracleにこれと同じものを使用すると、まったく接続されません。次の例外が発生しています:

    Initial SessionFactory creation failed.
    java.lang.NullPointerException
at      org.hibernate.engine.jdbc.internal.
    JdbcServicesImpl.configure(JdbcServicesImpl.java:207)
at org.hibernate.service.internal.
     StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java:75)
at org.hibernate.service.internal.
    AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:159)
at org.hibernate.service.internal.
    AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:131)
at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:78)
at org.hibernate.cfg.Configuration.buildSettingsInternal(Configuration.java:2283)
at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:2279)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1748)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1788)
at  
com.bosch.asaw.utilities.HibernateUtil.createSessionFactory(HibernateUtil.java:25)
at com.bosch.asaw.utilities.HibernateUtil.<init>(HibernateUtil.java:17)
at com.bosch.asaw.dao.testhibernate.main(testhibernate.java:19)
   Exception in thread "main" java.lang.ExceptionInInitializerError
at 
 com.bosch.asaw.utilities.HibernateUtil.createSessionFactory(HibernateUtil.java:30)
at com.bosch.asaw.utilities.HibernateUtil.<init>(HibernateUtil.java:17)
at com.bosch.asaw.dao.testhibernate.main(testhibernate.java:19)
    Caused by: java.lang.NullPointerException
at 
org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcServicesImpl.java:207
at org.hibernate.service.internal.
StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java:75)
at  org.hibernate.service.internal.
AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:159)
at     

org.hibernate.service.internal.AbstractServiceRegistryImpl.
getService(AbstractServiceRegistryImpl.java:131)
at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:78)
at org.hibernate.cfg.Configuration.buildSettingsInternal(Configuration.java:2283)
at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:2279)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1748)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1788)
at 
com.bosch.asaw.utilities.HibernateUtil.createSessionFactory(HibernateUtil.java:25)
... 2 more

誰が私が間違っているのか教えてください。Oracleサーバーのポート、sid、およびホスト名を再確認しました。助けてください。

4

2 に答える 2

0

設定ファイルに問題があると思います。

次の oracle 構成ファイルを参照してください。

hibernate.cfg.xml

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<休止状態の構成>
<セッションファクトリー>
<!-- データベース接続設定 -->
<property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
<property name="connection.username">ランガ</property>
<property name="connection.password">ランガ</property>
<property name="connection.url">jdbc:oracle:thin:@localhost:1521:XE</property>

<!-- JDBC 接続プール (組み込みを使用) -->
<property name="connection.pool_size">1</property>

<!-- SQL 方言 -->
<property name="dialect">org.hibernate.dialect.Oracle10gDialect</property>

<!-- 二次キャッシュを無効にする -->
<property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>

<!-- 実行されたすべての SQL を stdout にエコー -->
<property name="show_sql">true</property>

<!-- 起動時にデータベース スキーマを削除して再作成 -->
<property name="hbm2ddl.auto">作成</property>

<mapping resource="com/ranga/mapping/Person.hbm.xml"/>

</セッションファクトリー>
</休止状態の構成>

HibernateUtil.java

 package com.ranga.util;

import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.service.ServiceRegistryBuilder;

public class HibernateUtil {
     private static final SessionFactory sessionFactory;
     private static final ServiceRegistry serviceRegistry;
     static {
        try {
           // Create the SessionFactory from hibernate.cfg.xml
           Configuration configuration = new Configuration();
           configuration.configure();
           serviceRegistry = new ServiceRegistryBuilder().applySettings(
           configuration.getProperties()).buildServiceRegistry();
           sessionFactory = configuration.buildSessionFactory(serviceRegistry);
        } catch (Throwable ex) {
           // Make sure you log the exception, as it might be swallowed
           System.err.println("Initial SessionFactory creation failed." + ex);
           throw new ExceptionInInitializerError(ex);
        }
}

public static SessionFactory getSessionFactory() {
     return sessionFactory;
}

public static void closeSessionFactory() {
        if (sessionFactory != null)
            sessionFactory.close();
    }
}

完全なサンプル プログラムが必要な場合は、github ( https://github.com/rangereddy/Hibernate4ExampleUsingMaven/ )からダウンロードしてください。

于 2014-05-13T05:59:19.087 に答える
0

ビルド セッション ファクトリの新しいコードを試しましたか?

SessionFactory factory = null;
try {
     Configuration configuration = new Configuration();
     configuration.configure("resources/hibernate.cfg.xml");

    ServiceRegistryBuilder serviceRegistryBuilder = new ServiceRegistryBuilder();
    serviceRegistryBuilder.applySettings(configuration.getProperties());
    serviceRegistry = serviceRegistryBuilder.buildServiceRegistry();

    factory = configuration.buildSessionFactory(serviceRegistry);  
} catch (Throwable ex) {

    System.err.println("Initial SessionFactory creation failed.");
    ex.printStackTrace();
    throw new ExceptionInInitializerError(ex);

}
于 2014-03-05T07:58:15.710 に答える