gpt4 book ai didi

mysql - 如何在 doobie 中配置 transactor?

转载 作者:行者123 更新时间:2023-11-29 02:38:38 25 4
gpt4 key购买 nike

最近我开始学习 doobie,但我无法无误地创建一个 hikari 事务处理程序。我正在使用 mysql,Intellij-Idea。

这是我的 build.sbt 文件

name := "doobie"
version := "0.1"
//scalaVersion := "2.13.1"
scalacOptions += "-Ypartial-unification" // 2.11.9+
libraryDependencies ++= {
lazy val doobieVersion = "0.8.4"
Seq(
"org.tpolecat" %% "doobie-core" % doobieVersion,
"org.tpolecat" %% "doobie-h2" % doobieVersion,
"org.tpolecat" %% "doobie-hikari" % doobieVersion,
"org.tpolecat" %% "doobie-quill" % doobieVersion,
"org.tpolecat" %% "doobie-specs2" % doobieVersion,
"org.tpolecat" %% "doobie-scalatest" % doobieVersion % "test",
"mysql" % "mysql-connector-java" % "8.0.17",
"org.slf4j" % "slf4j-api" % "1.7.5",
"ch.qos.logback" % "logback-classic" % "1.0.9"
)
}

resolvers ++= Seq(
"Typesafe repository" at "http://repo.typesafe.com/typesafe/releases/"
)

这是我的 Connection.scala 文件

import cats.effect.IO
import com.zaxxer.hikari.{HikariConfig, HikariDataSource}
import doobie.hikari.HikariTransactor

trait Connection {

val config = new HikariConfig()
config.setJdbcUrl("jdbc:mysql://localhost:quill_demo")
config.setUsername("admin")
config.setPassword("password")
config.setMaximumPoolSize(5)

val transactor: IO[HikariTransactor[IO]] =
IO.pure(HikariTransactor.apply[IO](new HikariDataSource(config)))

}

问题出在上面的文件 IO.pure(HikariTransactor.apply[IO](new HikariDataSource(config))) 语句中。这里最后一个闭合的括号中的 3 个给出了 3 个错误,如下所示。

No implicit arguments of type: ContextShift[IO]
Unspecified value parameters: connectEC: ExecutionContext, transactEC: ExecutionContext
No implicits found for parameter evidence$2: ContextShift[IO]

所有我想知道的,如何正确地做到这一点。

最佳答案

尝试添加以下导入和隐式

import scala.concurrent.ExecutionContext

implicit val cs = IO.contextShift(ExecutionContext.global)

关于mysql - 如何在 doobie 中配置 transactor?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58538311/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com