1

我想以编程方式从休眠配置中获取数据源。这是我写的代码:

public static DataSource getDatasource(Configuration configuration){
    ServiceRegistry registry = new ServiceRegistryBuilder().applySettings(configuration.getProperties()).buildServiceRegistry();
    SessionFactoryImpl session = (SessionFactoryImpl)configuration.buildSessionFactory(registry);
    DatasourceConnectionProviderImpl provider = (DatasourceConnectionProviderImpl) session.getConnectionProvider();
    return provider.getDataSource();
}

但是我在运行应用程序时遇到了异常:

Exception in thread "main" org.hibernate.HibernateException: Missing table: CONTACTS
at org.hibernate.cfg.Configuration.validateSchema(Configuration.java:1281)
at org.hibernate.tool.hbm2ddl.SchemaValidator.validate(SchemaValidator.java:155)
at org.hibernate.internal.SessionFactoryImpl.<init>(SessionFactoryImpl.java:508)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1769)
at com.heavenize.Migrations.getDatasource(Migrations.java:30)
at com.heavenize.Migrations.main(Migrations.java:60)

我正在执行一些数据库迁移,我需要数据源以编程方式传递给我的迁移工具。

似乎问题在于buildSessionFactory因为休眠试图将实体与数据库中的表进行映射。

该属性"hibernate.hbm2ddl.auto"设置为validate

有没有更好的方法来获取数据源?

4

1 回答 1

1

您收到的错误与检索DataSource. 这是因为 Hibernate 正在使用数据库验证数据模型并且没有发现它处于同步状态。您可以完全删除该hibernate.hbm2ddl.auto属性,然后将其默认为none并且不会进行任何验证。

于 2013-06-18T13:57:27.537 回答