使用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"
    }
  ]
}

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...