具有 Play 框架 2.1.x 的多个数据库
2022-09-03 06:47:37
我有 2 个需要连接的数据库。我可以在apprament.conf文件中轻松连接到它们,如下所示:
db.default.driver=org.postgresql.Driver
db.default.url="jdbc:postgresql://localhost/db1"
db.default.user=postgres
db.default.password="password"
db.secondary.driver=org.postgresql.Driver
db.secondary.url="jdbc:postgresql://localhost/db2"
db.secondary.user=postgres
db.secondary.password="password"
ebean.default="models.db1.*"
ebean.secondary="models.db2.*"
我在这些包中有我的模型类,并且DDL可以正确生成表。
问题在于实际使用这些实体。不在“默认”包中的任何内容都会引发此错误(以辅助数据库中的 Users 表为例)
如果我尝试查询表的所有行:
List<Users> users = Users.find.all();
它会抛出以下错误:
[PersistenceException: models.db2.Users is NOT an Entity Bean registered with this server?]
尽管我100%确定Users表位于后端,但它是DDL工作并正确制作此表的注册表,并且我正在导入正确的类。
是否有某种方法需要查询不在默认包中的模型类?
编辑:我意识到堆栈跟踪显示它正在尝试使用默认服务器。如何使其使用辅助服务器?
at com.avaje.ebeaninternal.server.core.DefaultServer.createQuery(DefaultServer.java:989) ~[avaje-ebeanorm-server.jar:na]
at com.avaje.ebeaninternal.server.core.DefaultServer.createQuery(DefaultServer.java:946) ~[avaje-ebeanorm-server.jar:na]
at com.avaje.ebeaninternal.server.core.DefaultServer.find(DefaultServer.java:982) ~[avaje-ebeanorm-server.jar:na]
at play.db.ebean.Model$Finder.all(Model.java:254) ~[play-java-ebean_2.10.jar:2.1.3]