如何在Hibernate中映射动态创建的表?
我正在开发一个Web应用程序。 我们在项目中使用Hibernate作为ORM。 实际上,我们的应用程序根据用户选择动态创建一些表。 用户可以选择表名,列名,然后他/她可以从csv文件导入数据。 所以我的问题是:如何使用Hibernate和Java对象映射这个动态创建的表?
它可以动态完成,但有点凌乱:
在构建SessionFactory之前,您需要动态更改Hibernate的Configuration对象。 如果您正在使用Spring,可以通过覆盖AnnotationSessionFactoryBean
postProcessAnnotationConfiguration()
方法来完成; 否则你只需要在调用buildSessionFactory()
之前使用Configuration对象。
如果您需要在没有重新启动应用程序的情况下执行此操作,那么您正在寻找重建SessionFactory(这意味着您的用户必须等到完成)或使用专门用于您的自定义类的单独SessionFactory实例(这几乎是不可能的)如果您的自定义类需要引用您的内置类)。
您可以通过configuration.getMappings()
访问类/表映射。 然后,您需要通过Table API创建一个新的表映射,并通过addTable()
将其添加到配置中。 使用表示类映射的PersistentClass也必须完成同样的事情。 如果您使用相同的类来表示多个实体(例如映射多个表),请确保为每个实体使用唯一的实体名称。 每次重启应用程序时都必须执行此操作(更改配置)。
有多少表是动态创建的? 表是否相似,您只需更改数据库名称?
以下是更改表名的讨论: http : //www.experts-exchange.com/Programming/Languages/Java/J2EE/Frameworks/Spring/Q_24237099.html
如果您要完全构建新表,是否可以使用视图,并将人们引导至视图?
为什么要使用Hibernate,而不是仅仅在JDBC中动态创建查询?
数据库解决方案 – 您可以创建一个视图并将其指向一个或另一个表(假设结构相同)。
创建视图HIBERNATE_NAME为SELECT * FROM TABLE_A
或CREATE VIEW HIBERNATE_NAME为SELECT * FROM TABLE_B
您需要应用程序来执行本机SQL(DDL),但这应该比Hibernate hacks更容易