mysql - 如何在 doobie 中配置交易者?
问题描述
最近我开始学习 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)
推荐阅读
- java - Java TCP 客户端-服务器连接:始终打开以侦听服务器
- php - 在多维json数组中添加所有具有匹配键的值
- java - Kotlin 可以和 openjdk 一起使用吗?
- rust - 如何更改 Arc 的值
在结构中? - javascript - 为什么我的数组不能作为删除函数的参数?
- parquet - 尝试运行具有大量列的极其基本的 AWS-glue 爬虫时出现“内部服务异常”
- python - pyautogui.moveTo 似乎没有生成鼠标事件
- django - Django ModelForm 小部件和非小部件字段排序
- reactjs - 尝试使用 .strike() 在 React 中删除 Li 元素
- php - 从数据库中删除记录时如何删除文件?(拉拉维尔)