どのように注釈と休止状態でプログラムデータベーススキーマを検証するには?
-
22-09-2019 - |
質問
org.hibernate.cfg.ConfigurationオブジェクトがvalidateSchemaメソッドを呼び出すことにより、プログラム的に検証を実行するために使用することができるようです。 しかし、この方法では、方言とのDatabaseMetaDataオブジェクトを必要とします。 私は春を使用していると私は春のコンテキストからAnnotationSessionFactoryBeanオブジェクトを手に入れることができます。これまでのところ私は、次のコードを持っています:
AnnotationSessionFactoryBean factory = null;
factory = (AnnotationSessionFactoryBean) context.getBean("AnnotationSessionFactory");
Configuration configuration = factory.getConfiguration();
//the following line does not work, ConnectionHelper hierarchy is not visible outside the package
ConnectionHelper connectionHelper =
new ManagedConnectionProviderConnectionHelper(factory.getHibernateProperties());
Dialect dialect = Dialect.getDialect(factory.getHibernateProperties());
Connection connection = null;
DatabaseMetadata databaseMetadata = null;
try {
databaseMetadata = new DatabaseMetadata(connection, dialect);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
configuration.validateSchema(dialect, databaseMetadata);
アムI右のトラックに? DatabaseMetaDataのを構築するために、私は、そのような接続オブジェクトを取得することはできませんので、ConnectionHelper階層は、パッケージの可視外ではありません。どのように私はこれを実装することができますか?
編集: 私はいくつかの進歩を遂げていると思います。 SchemaValidatorクラスがあります。コードは次のようになります:
AnnotationSessionFactoryBean factory = context.getBean("&AnnotationSessionFactory");
Configuration configuration = factory.getConfiguration();
SchemaValidator validator = new SchemaValidator(configuration);
validator.validate();
Howerver、今私は、次のエラーを取得しています:
org.hibernate.HibernateException:いいえローカルデータソースは、設定が見つかりません - 「データソース」プロパティはLocalSessionFactoryBean
に設定する必要があります解決
春を使用した場合、
最後に、これは簡単なことではありません。
:私はこのようなAnnotationSessionFactoryBeanを拡張し、それを行うために管理しましたpublic class SchemaValidatingAnnotationSessionFactoryBean extends
AnnotationSessionFactoryBean {
public void validateDatabaseSchema() throws DataAccessException {
logger.info("Validating database schema for Hibernate SessionFactory");
HibernateTemplate hibernateTemplate = new HibernateTemplate(
getSessionFactory());
hibernateTemplate.setFlushMode(HibernateTemplate.FLUSH_NEVER);
hibernateTemplate.execute(new HibernateCallback() {
public Object doInHibernate(Session session)
throws HibernateException, SQLException {
Connection con = session.connection();
Dialect dialect = Dialect.getDialect(getConfiguration()
.getProperties());
DatabaseMetadata metadata = new DatabaseMetadata(con, dialect);
Configuration configuration = getConfiguration();
configuration.validateSchema(dialect, metadata);
return null;
}
});
}
}
他のヒント
私はHibernateマッピングの検証を呼び出すための簡単な解決策を発見したことは私のための作品:のLocalSessionFactoryBean.validateDatabaseSchema()の(事実上のダンの答えのコードと同じことをしている)。
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = { "/some-test-context.xml" })
public class TestMapping {
@Autowired
ApplicationContext context;
@Test
public void validateSchema() {
AnnotationSessionFactoryBean factory = (AnnotationSessionFactoryBean)context
.getBean("&mySessionFactory");
factory.validateDatabaseSchema();
}
}
所属していません StackOverflow