问题描述
我想连接到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"
}
]
}