メインコンテンツまでスキップ
メインコンテンツまでスキップ

jdbcテーブル関数

注記

clickhouse-jdbc-bridgeには実験的なコードが含まれており、もはやサポートされていません。信頼性の問題やセキュリティの脆弱性を含む可能性があります。使用は自己責任で行ってください。
ClickHouseでは、より良い代替手段を提供するClickHouse内蔵のテーブル関数を使用することを推奨します。これにより、アドホッククエリシナリオ(Postgres、MySQL、MongoDBなど)が実現できます。

jdbc(datasource, schema, table) - JDBCドライバーを介して接続されるテーブルを返します。

このテーブル関数は、別のclickhouse-jdbc-bridgeプログラムが実行されている必要があります。
Nullable型をサポートしています(クエリされたリモートテーブルのDDLに基づきます)。

SELECT * FROM jdbc('jdbc:mysql://localhost:3306/?user=root&password=root', 'schema', 'table')
SELECT * FROM jdbc('mysql://localhost:3306/?user=root&password=root', 'select * from schema.table')
SELECT * FROM jdbc('mysql-dev?p1=233', 'num Int32', 'select toInt32OrZero(''{{p1}}'') as num')
SELECT *
FROM jdbc('mysql-dev?p1=233', 'num Int32', 'select toInt32OrZero(''{{p1}}'') as num')
SELECT a.datasource AS server1, b.datasource AS server2, b.name AS db
FROM jdbc('mysql-dev?datasource_column', 'show databases') a
INNER JOIN jdbc('self?datasource_column', 'show databases') b ON a.Database = b.name