Пример Doob ie жалуется на несоответствие индекса столбца - PullRequest
1 голос
/ 21 февраля 2020

Опробовать фондовый пример Doob ie и получить исключение с жалобой на "недопустимый индекс столбца". Мой запрос очень прост: он выбирает два столбца из одной таблицы Oracle, и я ожидаю, что Doob ie отобразит это в последовательность экземпляров класса case с двумя совпадающими свойствами. Я выполнил этот запрос в SQL IDE, и он работает нормально. Я предполагаю, что есть несоответствие между количеством параметров PreparedStatement (созданного Doob ie) и количеством параметров, переданных в (один) - но я не знаю почему. Это мой первый контакт с Doob ie, поэтому я могу неправильно понять что-то простое.

Исключение составляет java.sql.SQLException: Invalid column index. Есть идеи, что я делаю не так?

import doobie._
import doobie.implicits._
import cats.effect.IO
import scala.concurrent.ExecutionContext

/**
 * @see https://tpolecat.github.io/doobie/
 */
object DoobieExampleOne {
  implicit val cs = IO.contextShift(ExecutionContext.global)
  val jdbcUrl = "jdbc:oracle:thin:@(DESCRIPTION=...)"

  val xa = Transactor.fromDriverManager[IO](
    "oracle.jdbc.driver.OracleDriver", jdbcUrl, "myUser", "myPswd"
  )

  def main(args: Array[String]): Unit = {
    find(idPrefix = "somePfx").transact(xa).unsafeRunSync
  }

  case class SomeEntity(identifier_value: String, some_id: Long)

  def find(idPrefix: String): ConnectionIO[Option[SomeEntity]] =
    // This query runs correctly on the command line
    sql"SELECT identifier_value, some_id FROM some_table WHERE identifier_value LIKE '$idPrefix'"
      .query[SomeEntity].option
}
// Exception in thread "main" java.sql.SQLException: Invalid column index

1 Ответ

1 голос
/ 21 февраля 2020

Нашли решение, внимательно прочитав пример на складе: параметр запроса не должен быть заключен в кавычки. Правильный синтаксис показан ниже:

sql"SELECT identifier_value, some_id FROM some_table WHERE identifier_value LIKE $idPrefix"
...