找不到参数 F 的隐式值:cats.Applicative[F]

Could not find implicit value for parameter F: cats.Applicative[F]

我目前正在学习关于猫的教程。

本教程为我提供了一个我不应该编辑的猫面包(使用 Slick)的存储库,然后要求我实现不同的方法。不幸的是,我被困在了一些看起来很明显的事情上。

方法给了我

  def findByName(name: String)(implicit ec: ExecutionContext): DBIO[Option[Breed]] = {
    query.filter(_.name === name).result.headOption
  }

breedsRepository 中,我应该实现以下方法:

def findBreed(name: Either[Int, String]): DBIO[Either[Int, Breed]] = ???

我考虑过:

def findBreed(name: Either[Int, String]): DBIO[Either[Int, Breed]] =
    name.traverse(n => breedsRepository.findByName(n).map(_.get))

但我收到错误 could not find implicit value for parameter F: cats.Applicative[F] 谁能帮帮我?

编译以下代码:

import slick.jdbc.PostgresProfile.api._
import scala.concurrent.ExecutionContext
import scala.concurrent.ExecutionContext.Implicits.global
import cats.implicits._
import com.rms.miu.slickcats.DBIOInstances._

object breedsRepository {   
  case class Breed(name: String, price: Double)

  class BreedTable(tag: Tag) extends Table[Breed](tag, "BREEDS") {
    def name = column[String]("NAME", O.PrimaryKey)
    def price = column[Double]("PRICE")
    def * = (name, price) <> (Breed.tupled, Breed.unapply)
  }
  val query = TableQuery[BreedTable]

  def findByName(name: String)(implicit ec: ExecutionContext): DBIO[Option[Breed]] = {
    query.filter(_.name === name).result.headOption
  }

  def findBreed(name: Either[Int, String]): DBIO[Either[Int, Breed]] =
    name.traverse[DBIO, Int, Breed](n => findByName(n).map(_.get))
}

build.sbt

name := "slickdemo"

version := "0.1"

scalaVersion := "2.12.6"

scalacOptions += "-Ypartial-unification"

libraryDependencies ++= Seq(
  "com.typesafe.slick" %% "slick" % "3.2.3",
  "org.slf4j" % "slf4j-nop" % "1.6.4",
  "com.typesafe.slick" %% "slick-hikaricp" % "3.2.3"
)

libraryDependencies += "org.typelevel" %% "cats-core" % "1.0.1"

libraryDependencies += "com.rms.miu" %% "slick-cats" % "0.7.1.1"