微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用sqlline通过Calcite驱动程序连接到JDBC数据库

如何解决使用sqlline通过Calcite驱动程序连接到JDBC数据库

我想连接到JDBC DB,例如通过使用sqlline git存储库中包含的calcite shell脚本包装程序的Calcite驱动程序进行Postgres。我面临着如何指定目标JDBC Postgres驱动程序的问题。最初我尝试过:

CLAsspATH=/Users/davidkubecka/git/calcite/build/libs/postgresql-42.2.18.jar ./sqlline -u jdbc:calcite:model=model.json

model.json是这个:

{
  "version": "1.0","defaultSchema": "tpch","schemas": [
    {
      "name": "tpch","type": "jdbc","jdbcUrl": "jdbc:postgresql://localhost/*","jdbcSchema": "tpch","jdbcUser": "*","jdbcPassword": "*"
    }
  ]
}

但是

  • 首先,即使模型中已经指定了用户名和密码,我也被要求输入用户名和密码。
  • 第二,填写凭据后,我仍然出现错误
java.lang.RuntimeException: java.sql.sqlException: Cannot create JDBC driver of class '' for connect URL 'jdbc:postgresql://localhost/*'

所以我的问题是是否支持这种情况(通过sqlline在Calcite驱动程序内部使用JDBC驱动程序),如果可以,我该如何建立连接?

解决方法

尝试将jdbc驱动程序包括在架构定义中,并确保它在类路径中。此外,将数据库名称添加到jdbc Url。您的model.json可能看起来像:

{
  "version": "1.0","defaultSchema": "tpch","schemas": [
    {
      "name": "tpch","type": "jdbc","jdbcUrl": "jdbc:postgresql://localhost/my_database","jdbcSchema": "tpch","jdbcUser": "*","jdbcPassword": "*","jdbcDriver": "org.postgresql.Driver"
    }
  ]
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?