光滑的codegen没有提供任何输出

时间:2017-03-15 06:37:30

标签: scala sqlite slick slick-codegen

我正在尝试使用当前版本的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")
    }
}

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

1 个答案:

答案 0 :(得分:0)

以上情况正在发生,因为底层代码默默地抛出异常。这个例外的原因是我使用的是sqlite的“功能”,如果你没有提到架构中的数据类型,sqlite会认为它是文本类型。但是,这会为光滑的代码带来问题。

更多details here。直接的解决方案是修复架构,但我认为现在已经修复了这个问题。