有一个用于配置单元的jdbc驱动程序,但似乎无法正常运行。我使用默认的doobie Transactor像
一样连接到它val xa = Transactor.fromDriverManager[IO](
"org.apache.hive.jdbc.HiveDriver", url, username, pass
)
myQuery.transact(xa).unsafeRunSync
我收到一条错误消息
[错误]线程“主”中的异常java.sql.SQLFeatureNotSupportedException:不支持方法 org.apache.hive.jdbc.HiveConnection.rollback(HiveConnection.java:1327)出现[错误] [错误]在doobie.free.KleisliInterpreter $ ConnectionInterpreter $$ anonfun $ rollback $ 1.apply(kleisliinterpreter.scala:643) [错误]在doobie.free.KleisliInterpreter $ ConnectionInterpreter $$ anonfun $ rollback $ 1.apply(kleisliinterpreter.scala:643) [错误]在doobie.free.KleisliInterpreter $$ anonfun $ primitive $ 1 $ anonfun $ apply $ 1.apply(kleisliinterpreter.scala:99)
如何使用Doobie连接到Hive?
答案 0 :(得分:2)
您需要通过新策略禁用Transactor中的“ after”和“ oops”。 这是
import doobie.free.connection.unit
import doobie.util.transactor.Strategy
val hiveStrategy = Strategy.default.copy(
after = unit, oops = unit)
val xa = Transactor.strategy.set(
Transactor.fromDriverManager[IO](
"org.apache.hive.jdbc.HiveDriver", url, username, pass),
hiveStrategy)
myQuery.transact(xa).unsafeRunSync