Конфигурация БД:
db=mysql://root@localhost/db
jpa.dialect=org.hibernate.dialect.MySQLDialect
....
db_other.url=jdbc:mysql://localhost/db2
db_other.driver=com.mysql.jdbc.Driver
db_other.user=root
db_other.pass=
db_other.jpa.dialect=org.hibernate.dialect.MySQLDialect
В этих базах данных у меня есть абсолютно точные таблицы (клоны).Но разница в том, что в этих таблицах разные значения.('Value # 1' и 'Value # 2' соответственно).
Простая модель:
package models;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.PersistenceUnit;
import javax.persistence.Table;
import play.db.jpa.GenericModel;
@Entity
@PersistenceUnit(name="other")
@Table(name="testtable")
public class DbTest extends GenericModel {
@Id
public String value;
}
Остальной код:
List<DbTest> lst = DbTest.findAll();
if(!lst.isEmpty())
System.out.println(lst.get(0).value);
Всегдапечатает значение # 1.(Это должно быть 'Value # 2', как в db2).Конечно, я указал @PersistenceUnit (name = "other").Но это не имеет никакого эффекта.Даже если я изменю имя pers.unit на random, никаких ошибок.Эта аннотация не работает или просто игнорируется?Или я где-то ошибся?: /
ps Также я попытался получить EntityManager, как показано в руководстве по фреймворку (/documentation/jpa#multiple).
EntityManager em = JPA.getJPAConfig("other").em();
Но это невозможно: <<Метод getJPAConfig (String) не определен для типа JPA >>