我有一个包含多个用户/模式的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的哪个架构?
答案 0 :(得分:1)
我发现了怎么做。而不是使用OracleProfile.defaultTable
我手动定义了我需要的表和视图,如下所示:
val modelAction = OracleProfile.createModel(
Some(MTable.getTables(None, Some("MYSCHEMA"), None, Some(Seq("TABLE", "VIEW"))))
)