未创建Phantom DSL 2.24表

时间:2018-07-25 18:09:33

标签: scala phantom-dsl

最近尝试迁移到最新的幻影版本2.24.8。我创建了一个虚拟项目,但是遇到了一些我不知道的问题。这是我的代码:

import com.outworkers.phantom.connectors.{CassandraConnection, ContactPoints}
import com.outworkers.phantom.database.Database

import scala.concurrent.Future
import com.outworkers.phantom.dsl._

case class Test(id: String, timestamp: String)

abstract class Tests extends Table[Tests, Test] {

  object id extends StringColumn with PartitionKey

  object timestamp extends StringColumn with ClusteringOrder
}

abstract class ConcreteTests extends Tests with RootConnector {
  def addTest(l: Test): Future[ResultSet] = {
    //    store(l).consistencyLevel_=(ConsistencyLevel.LOCAL_ONE).future
    insert.value(_.id, l.id)
      .value(_.timestamp, l.timestamp)
      .consistencyLevel_=(ConsistencyLevel.QUORUM).future
  }

}

class MyDB(override val connector: CassandraConnection) extends Database[MyDB](connector) {

  object tests extends ConcreteTests with connector.Connector

  def init(): Unit = {
    tests.create
  }
}

object Test{
  def main(args: Array[String]): Unit = {
    val db = new MyDB(ContactPoints(Seq("127.0.0.1")).keySpace("tests"))
    db.init
    db.tests.addTest(Test("1", "1323234234"))
    println("Done")
  }
}

它已编译并在IntelliJ中运行并打印出“完成”。但是,永远不会创建任何表。也没有例外或警告。它什么也没做。我试图停止本地cassandra数据库。该代码抛出NoHostAvailableException。因此,它确实尝试连接本地数据库。有什么问题吗?

另一个奇怪的事情是我的build.sbt中有“ com.typesafe.play” %%“ play-json”%“ 2.6.9”。如果我删除该库,则相同的代码将引发以下异常:

Exception in thread "main" java.lang.NoClassDefFoundError: scala/reflect/runtime/package$
    at com.outworkers.phantom.column.AbstractColumn.com$outworkers$phantom$column$AbstractColumn$$_name(AbstractColumn.scala:55)
    at com.outworkers.phantom.column.AbstractColumn.com$outworkers$phantom$column$AbstractColumn$$_name$(AbstractColumn.scala:54)
    at com.outworkers.phantom.column.Column.com$outworkers$phantom$column$AbstractColumn$$_name$lzycompute(Column.scala:22)
    at com.outworkers.phantom.column.Column.com$outworkers$phantom$column$AbstractColumn$$_name(Column.scala:22)
    at com.outworkers.phantom.column.AbstractColumn.name(AbstractColumn.scala:58)
    at com.outworkers.phantom.column.AbstractColumn.name$(AbstractColumn.scala:58)
    at com.outworkers.phantom.column.Column.name(Column.scala:22)
    at com.outworkers.phantom.builder.query.InsertQuery.value(InsertQuery.scala:107)

真的不知道发生了什么。有什么帮助吗?

顺便说一句,我正在使用scala 2.12.6和JVM 1.8.181。

1 个答案:

答案 0 :(得分:0)

您没有使用正确的DSL方法创建表,请查看official guidetable.create所做的只是创建一个空的CreateQuery,您正在手动将返回类型强制为Unit

自动阻止创建方法位于Database上,而不在表上,因此您需要的是:

class MyDB(override val connector: CassandraConnection) extends Database[MyDB](connector) {

  object tests extends ConcreteTests with connector.Connector

  def init(): Unit = {
    this.create
  }
}

如果您想使用table实现相同的目标,则需要:

class MyDB(override val connector: CassandraConnection) extends Database[MyDB](connector) {

  object tests extends ConcreteTests with connector.Connector

  def init(): Unit = {
    import scala.concurrent.duration._
    import scala.concurrent.Await

    Await.result(tests.create.future(), 10.seconds)
  }
}

只有对future()方法的调用会触发对数据库的任何类型的操作,否则您只是在构建查询而不执行它。方法名称可能会造成混淆,我们将改进文档和将来的版本以使其更明显。

与游戏2.6.9的冲突看起来很奇怪,完全有可能与宏编译有关的幕后存在不兼容的依赖关系。将其作为一个单独的问题提出,我们一定可以对其进行看看。