我正在练习 Scala、Doobie 和 PostgreSQL。该数据库位于 Docker 容器中。我可以发布和更新职位,但无法获取所有职位。我不断收到以下错误。
我研究了其他类似的问题,但我的不同之处在于我只是想从数据库中获取所有内容,所以我不理解这个专栏问题。
我开始认为我需要一个 circe 编码器来从数据库中读取 Json ???下面的circe解码器在leftMap和show上抛出错误
implicit val get: Get[JobPostDetails] =
Get[Json].temap(_.as[JobPostDetails].leftMap(_.show))
case class JobPost(id: String, details: JobPostDetails)
case class JobPostDetails(title: String, description: String, salary: Double, employmentType: String, employer: String)
def createTable: doobie.Update0 = {
sql"""
|CREATE TABLE IF NOT EXISTS jobs (
| id TEXT PRIMARY KEY,
| details JSON NOT NULL
|)
""".stripMargin
.update
}
def getAll: doobie.Query0[JobPost] = {
sql"""
|SELECT id, details FROM jobs
""".stripMargin
.query[JobPost]
}
def getPosts: IO[List[JobPost]] = {
JobQueries.getAll.to[List].transact(xa)
}
09:01:50.452 [ioapp-compute-7] ERROR org.http4s.server.service-errors - Error servicing request: GET /api/v1/posts from 0:0:0:0:0:0:0:1
org.postgresql.util.PSQLException: The column index is out of range: 3, number of columns: 2.
at org.postgresql.jdbc.PgResultSet.checkColumnIndex(PgResultSet.java:2760) ~[postgresql-42.2.12.jar:42.2.12]
at org.postgresql.jdbc.PgResultSet.checkResultSet(PgResultSet.java:2780) ~[postgresql-42.2.12.jar:42.2.12]