一、JDBC

### --- ClickHouse链接JDBC

~~~ 允许CH通过 JDBC 连接到外部数据库。
~~~ 要实现JDBC连接,CH需要使用以后台进程运行的程序 clickhouse-jdbc-bridge。
~~~ 该引擎支持 Nullable 数据类型。
### --- 建表语法

CREATE TABLE [IF NOT EXISTS] [db.]table_name
(
columns list...
)
ENGINE = JDBC(dbms_uri, external_database, external_table)
### --- 引擎参数

~~~ dbms_uri — 外部DBMS的uri.
~~~ 格式jdbc:://:/?user=&password=. MySQL示例: jdbc:mysql://localhost:3306/?user=root&password=root.
~~~ external_database — 外部DBMS的数据库名.
~~~ external_table — external_database中的外部表名.

二、ClickHouse链接JDBC示例

### --- 在mysql下建表并加载数据

~~~ # 通过mysql控制台客户端来创建表
~~~ # Creating a table in MySQL server by connecting directly with it’s console client:
mysql> create database clickhouse;

mysql> CREATE TABLE `clickhouse`.`jdbc` (
-> `int_id` INT NOT NULL AUTO_INCREMENT,
-> `int_nullable` INT NULL DEFAULT NULL,
-> `float` FLOAT NOT NULL,
-> `float_nullable` FLOAT NULL DEFAULT NULL,
-> PRIMARY KEY (`int_id`));
~~~     # 导入数据

mysql> use clickhouse;
mysql> insert into jdbc (`int_id`, `float`) VALUES (1,2);

mysql> select * from jdbc;
+--------+--------------+-------+----------------+
| int_id | int_nullable | float | float_nullable |
+--------+--------------+-------+----------------+
| 1 | NULL | 2 | NULL |
+--------+--------------+-------+----------------+
### --- 在CH服务端创建表,并从中查询数据:

~~~ # 在clickhouse建表并查询数据是否链接成功
hadoop01 :) CREATE TABLE jdbc_table
(
`int_id` Int32,
`int_nullable` Nullable(Int32),
`float` Float32,
`float_nullable` Nullable(Float32)
)ENGINE JDBC('jdbc:mysql://hadoop03:3306/?user=root&password=12345678', 'clickhouse', 'jdbc');
~~~输出参数
CREATE TABLE jdbc_table
(
`int_id` Int32,
`int_nullable` Nullable(Int32),
`float` Float32,
`float_nullable` Nullable(Float32)
)
ENGINE = JDBC('jdbc:mysql://hadoop03:3306/?user=root&password=12345678', 'clickhouse', 'jdbc')

Ok.
~~~     # 查看数据是否链接成功

hadoop01 :) select * from jdbc_table;

┌─int_id─┬─int_nullable─┬─float─┬─float_nullable─┐
| 1 | NULL | 2 | NULL |
└────────┴──────────────┴───────┴────────────────┘











Walter Savage Landor:strove with none,for none was worth my strife.Nature I loved and, next to Nature, Art:I warm'd both hands before the fire of life.It sinks, and I am ready to depart

                                                                                                                                                   ——W.S.Landor