最近尝试迁移到最新的幻影版本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。
答案 0 :(得分:0)
您没有使用正确的DSL方法创建表,请查看official guide。 table.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的冲突看起来很奇怪,完全有可能与宏编译有关的幕后存在不兼容的依赖关系。将其作为一个单独的问题提出,我们一定可以对其进行看看。