ich Probleme habe mit in Spring MVC "mit mehreren Datenbanken arbeiten" - Hibernate JPASpring MVC mehrere Entitäten Datenbank persistance
Ich habe zwei Datenbanken USER_DB und portal_db genannt. Ich muss mit ihnen in verschiedenen jpa Einheiten arbeiten.
hier ist mein persistance.xml
<?xml version="1.0" encoding="UTF-8" ?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd" version="1.0">
<persistence-unit name="user_unit" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>Package.Entity1</class>
<properties>
<property name="hibernate.connection.url" value="jdbc:postgresql://localhost/user_db" />
<property name="hibernate.connection.useUnicode" value="true" />
<property name="hibernate.connection.characterEncoding" value="UTF-8" />
<property name="hibernate.connection.driver_class" value="org.postgresql.Driver" />
<property name="hibernate.connection.username" value="postgres" />
<property name="hibernate.connection.password" value="" />
<property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQL82Dialect" />
<!--<property name="hibernate.hbm2ddl.auto" value="create-drop" />-->
<property name="hibernate.hbm2ddl.auto" value="validate" />
<property name="hibernate.show_sql" value="true" />
<property name="hibernate.format_sql" value="true" />
</properties>
</persistence-unit>
<persistence-unit name="portal_unit" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>Package.Entity2</class>
<properties>
<property name="hibernate.connection.url" value="jdbc:postgresql://localhost/portal_db" />
<property name="hibernate.connection.useUnicode" value="true" />
<property name="hibernate.connection.characterEncoding" value="UTF-8" />
<property name="hibernate.connection.driver_class" value="org.postgresql.Driver" />
<property name="hibernate.connection.username" value="postgres" />
<property name="hibernate.connection.password" value="" />
<property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQL82Dialect" />
<!--<property name="hibernate.hbm2ddl.auto" value="create-drop"/>-->
<property name="hibernate.hbm2ddl.auto" value="validate"/>
<property name="hibernate.show_sql" value="true"/>
<property name="hibernate.format_sql" value="true"/>
</properties>
</persistence-unit>
</persistence>
Problem ist, wenn ich create-Drop und mein Projekt ausführen, es meine beiden entites in beiden Datenbanken erstellt. Wie die Tabelle, die nur von Package.Entity1
in user_unit erstellt werden sollte, wird auch in portal_unit erstellt.
Und wenn ich wählen, einfügen, aktualisieren meine enites, ich persist Einheit in jedem meiner individuellen DAO.
zum Beispiel der Umsetzung in Entity Dao ich habe:
EntityManagerFactory emf = Persistence.createEntityManagerFactory(persistenceUnit);
wo persistenceUnit user_unit
oder portal_unit
je nach Implementierung sein könnte.
Welche Änderungen sollte ich vornehmen, damit es nicht die gleiche Tabelle in beiden Datenbanken erstellt?
Es funktionierte. Danke :) Ich markiere so schnell wie möglich die richtige Antwort. –