我尝试以编程方式使用Apache Drill的JDBC驱动程序。
以下是代码:
import java.sql.DriverManager
object SearchHbaseWithHbase {
def main(args: Array[String]): Unit = {
Class.forName("org.apache.drill.jdbc.Driver")
val zkIp = "192.168.3.2:2181"
val connection = DriverManager.getConnection(s"jdbc:drill:zk=${zkIp};schema:hbase")
connection.setSchema("hbase")
println(connection.getSchema)
val st = connection.createStatement()
val rs = st.executeQuery("SELECT * FROM Label")
while (rs.next()){
println(rs.getString(1))
}
}
}
我设置了数据库模式,类型为:hbase,Like:
connection.setSchema("hbase")
但它失败了错误代码:
线程“main”中的异常java.sql.SQLException:VALIDATION ERROR: 从第1行第15列到第1行第19列:未找到表'标签' SQL Query null
Label表正好在我的hbase中退出。 当我使用sqline时,我可以找到我的数据:
sqline -u jdbc:drill:zk....
use hbase;
input :select * from Label;
答案 0 :(得分:1)
我已经解决了这个问题。我混淆了钻头的架构和jdbc驱动架构...... 正确的代码应该是:
object SearchHbaseWithHbase{
def main(args: Array[String]): Unit = {
Class.forName("org.apache.drill.jdbc.Driver")
val zkIp = "192.168.3.2:2181"
val p = new java.util.Properties
p.setProperty("schema","hbase")
// val connectionInfo = new ConnectionInfo
val url = s"jdbc:drill:zk=${zkIp}"
val connection = DriverManager.getConnection(url, p)
// connection.setSchema("hbase")
// println(connection.getSchema)
val st = connection.createStatement()
val rs = st.executeQuery("SELECT * FROM Label")
while (rs.next()){
println(rs.getString(1))
}
}
}