1

我正在尝试将当前版本的 slick 和 slick-codegen (3.2.0) 与 sqlite 数据库一起使用。当我尝试列出表格时,我得到了正确的名称。但是,当我尝试生成与表对应的类时,我没有得到任何输出。

这有效:

object TableCodeGenerator extends App
{
    val db = Database.forURL("jdbc:sqlite:/home/samik/db/mydb.db", driver = "org.sqlite.JDBC")
    val tables = Await.result(db.run(MTable.getTables), 1 second).toList
    tables.foreach(println)
}

我得到下面的输出:

MTable(MQName(models),TABLE,null,None,None,None)
MTable(MQName(users),TABLE,null,None,None,None)

但是,以下代码,直接以相同的方式运行,不起作用:

object TableCodeGenerator extends App
{
    val db = Database.forURL("jdbc:sqlite:/home/samik/db/mydb.db", driver = "org.sqlite.JDBC")
    val dbio = SQLiteProfile.createModel(Some(MTable.getTables))
    val model = db.run(dbio)

    val codegenFuture: Future[SourceCodeGenerator] = model.map(model => new SourceCodeGenerator(model))

    codegenFuture.onSuccess
    {
        case codegen => codegen.writeToFile(
            "org.sqlite.JDBC",
            "/tmp",
            "my.package.dao",
            "Tables",
            "Tables.scala")
    }
}

意思是,代码运行成功,但我没有看到任何输出文件。有什么我想念的吗?

4

1 回答 1

0

发生上述情况是因为底层代码默默地抛出异常。这个异常的原因是我使用了 sqlite 的“特性”,如果你没有在模式中提到数据类型,sqlite 会假定它是文本类型。然而,这给光滑的代码带来了问题。

更多细节在这里。直接的解决方案是修复架构,但我认为这现在也已经修复了。

于 2017-08-02T13:22:22.653 回答