使用Slick 3.2指定Oracle架构

时间:2017-06-16 08:21:38

标签: oracle scala slick-3.0

我有一个包含多个用户/模式的Oracle数据库,我想为特定用户自动生成Slick Schema。这是我到目前为止所尝试的:

import scala.concurrent.ExecutionContext.Implicits.global

val profileInstance: JdbcProfile =
  Class.forName("slick.jdbc.OracleProfile$")
    .getField("MODULE$")
    .get(null).asInstanceOf[JdbcProfile]

val db = profileInstance.api.Database
  .forURL("jdbc:oracle:thin:@//myhost:myport/servicename","user","pass")

val modelAction = OracleProfile.createModel(Some(OracleProfile.defaultTables))
val model = Await.result(db.run(modelAction), Duration.Inf)

model.tables.foreach(println)

这不会打印任何内容,我想我必须提供当前架构才能使用,但我不知道该怎么做。

另一方面,我可以使用以下代码列出数据库的所有模式:

val resultSet = db.createSession().metaData.getSchemas.getStatement.getResultSet
while(resultSet.next()) {
  println(resultSet.getString(1))
}

如何指定我要使用Slick的哪个架构?

1 个答案:

答案 0 :(得分:1)

我发现了怎么做。而不是使用OracleProfile.defaultTable我手动定义了我需要的表和视图,如下所示:

val modelAction = OracleProfile.createModel(
  Some(MTable.getTables(None, Some("MYSCHEMA"), None, Some(Seq("TABLE", "VIEW"))))
)