如何在 quarkus 数据源上指定当前模式?

问题描述

嗨,我正在尝试配置 quarkus 以连接到 oracle 数据库。使用当前配置,我可以连接到数据库,但无法指定当前架构。

我遵循了文档并尝试使用 new-connection-sql 来设置当前架构。但它似乎不起作用。

quarkus.datasource.mydatasource.new-connection-sql=ALTER SESSION SET CURRENT_SCHEMA=SCHEMA_NAME

这是我的 application.properties 文件

quarkus.datasource.mydatasource.db-kind=oracle
quarkus.datasource.mydatasource.jdbc.driver=oracle.jdbc.driver.OracleDriver
quarkus.datasource.mydatasource.jdbc.url=jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=10.15.73.140)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=SN)))
quarkus.datasource.mydatasource.jdbc.min-size=3
quarkus.datasource.mydatasource.jdbc.max-size=20
quarkus.datasource.mydatasource.username=username
quarkus.datasource.mydatasource.password=password
quarkus.datasource.mydatasource.new-connection-sql=ALTER SESSION SET CURRENT_SCHEMA=SCHEMA_NAME

这里可能有什么问题?

谢谢。

解决方法

您可以尝试在连接 url 中设置架构。但是您要归档的内容,基本上是将每个用户请求路由到特定架构,您应该通过这种方式检查 hibernate multitenancy support,您可以将每个请求路由到您想要的数据库,但要注意有关参数的限制您可以与您合作以了解将您的请求发送到何处。

还要检查 hibernate catalog and schema configuration parameters