Программная конфигурация гибернации после конфигурации XML - PullRequest
0 голосов
/ 01 апреля 2011

Я пытаюсь вставить запись, используя спящий режим.Он отлично работает, когда база данных usernanme и пароль находятся в конфигурационном файле hibernate вместе со всеми другими свойствами.

Но когда я удаляю его из имени пользователя и пароля из файла конфигурации, я не могу вставить.Что я могу делать не так?

            Configuration c = new Configuration();
    c.configure();

    c.setProperty("connection.username", "abc" );
    c.setProperty("connection.password", "secret" ); 
    SessionFactory sessFact =   c.buildSessionFactory();
    Session sess = sessFact.openSession();

    Transaction tx = sess.beginTransaction();
            sess.save(inf);
    tx.commit();
    sess.close();

org.hibernate.exception.GenericJDBCException: Cannot open connection
at org.hibernate.exception.SQLStateConverter.handledNonSpecificException(SQLStateConverter.java:140)
at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:128)
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66)
at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:52)
at org.hibernate.jdbc.ConnectionManager.openConnection

....

Caused by: java.sql.SQLException: invalid arguments in call
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:146)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:208)
at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:236)
at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:414)
at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:165)
at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:35)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:801)
at java.sql.DriverManager.getConnection(DriverManager.java:525)
at java.sql.DriverManager.getConnection(DriverManager.java:140)
at     org.hibernate.connection.DriverManagerConnectionProvider.getConnection(DriverManagerConnectionProvider.java:133)
at org.hibernate.jdbc.ConnectionManager.openConnection(ConnectionManager.java:446)

Я хочу выбрать большинство свойств из файла конфигурации xml, кромеUID и пароль.

Заранее спасибо

Ответы [ 2 ]

5 голосов
/ 01 апреля 2011

Попробуйте с этим кодом:

    Configuration c = new Configuration();
    c.configure();

    c.setProperty("hibernate.connection.username", "abc" );
    c.setProperty("hibernate.connection.password", "secret" ); 

Вы пропустили добавление префикса гибернации для имен свойств.

0 голосов
/ 13 мая 2013

Интересно, как .configure до того, как .setProperty работал.Для меня мне пришлось .configure после .setProperty.Кроме того, мне пришлось позвонить .applySettings(configuration.getProperties()) в

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

, чтобы он работал.

Возможно, так как сейчас я использую Hibernate 3.0.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...