我尝试使用以下代码来平滑地创建数据库
部分构建依赖项
scalaVersion := "2.12.6"
libraryDependencies += "com.typesafe.play" %% "play-slick" % "3.0.0"
libraryDependencies += "mysql" % "mysql-connector-java" % "8.0.12"
_
val db = Database.forURL("jdbc:mysql://localhost", "user", "password")
val dbName = "database1"
Await.result(db.run(sqlu"CREATE DATABASE $dbName"), 1.second)
用户对*。*
拥有所有特权但是会引发异常
java.util.NoSuchElementException: Invoker.first
at slick.jdbc.Invoker.first(Invoker.scala:34)
at slick.jdbc.Invoker.first$(Invoker.scala:30)
at slick.jdbc.StatementInvoker.first(StatementInvoker.scala:16)
at slick.jdbc.StreamingInvokerAction$HeadAction.run(StreamingInvokerAction.scala:52)
at slick.jdbc.StreamingInvokerAction$HeadAction.run(StreamingInvokerAction.scala:51)
at slick.basic.BasicBackend$DatabaseDef$$anon$2.liftedTree1$1(BasicBackend.scala:240)
at slick.basic.BasicBackend$DatabaseDef$$anon$2.run(BasicBackend.scala:240) java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1135)
at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:635)
at java.base/java.lang.Thread.run(Thread.java:844)
请告诉我如何毫无例外地创建数据库。
我想为每个用户创建一个数据库,所以无法在application.conf
答案 0 :(得分:0)
我建议你经历一下
https://www.playframework.com/documentation/2.6.x/PlaySlick。
在application.conf
中正确设置数据库配置
slick.dbs.default.driver = "slick.driver.MySQLDriver$"
slick.dbs.default.db.driver = "com.mysql.jdbc.Driver"
slick.dbs.default.db.url = "jdbc:mysql://localhost/demoDBName"
slick.dbs.default.db.user = "root user name"
slick.dbs.default.db.password = ""
这将在运行您的应用程序时创建demoDBName
(如果不存在)。希望能帮助到你。