使用jdbc操作ClickHouse

2018年07月01日 01:33:00 狮子头儿 阅读数 10501
 
版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。

  • 创建maven项目引入依赖

引入ClickHouse驱动包

  1.  
    <dependency>
  2.  
    <groupId>ru.yandex.clickhouse</groupId>
  3.  
    <artifactId>clickhouse-jdbc</artifactId>
  4.  
    <version>0.1.40</version>
  5.  
    </dependency>
  • 修改ClickHouse配置文件

vim /etc/clickhouse-server/config.xml

配置jdbc访问端口

<http_port>8123</http_port>

配置ip地址

  1.  
    <listen_host>::1</listen_host>
  2.  
    <listen_host>172.16.1.23</listen_host>

注:需要配置listen_host,不然会出现 Connection refused的情况,修改完成之后需要重启

  • 编写测试类
  1.  
    package com.zhangwq;
  2.  
     
  3.  
    import java.sql.*;
  4.  
    import java.util.ArrayList;
  5.  
    import java.util.HashMap;
  6.  
    import java.util.List;
  7.  
    import java.util.Map;
  8.  
     
  9.  
    /**
  10.  
    * @author zhangwq
  11.  
    * @date 2018/6/30 20:58
  12.  
    */
  13.  
    public class ClickHouseJDBC {
  14.  
    public static void main(String[] args) {
  15.  
    String sqlDB = "show databases";//查询数据库
  16.  
    String sqlTab = "show tables";//查看表
  17.  
    String sqlCount = "select count(*) count from ontime";//查询ontime数据量
  18.  
    exeSql(sqlDB);
  19.  
    exeSql(sqlTab);
  20.  
    exeSql(sqlCount);
  21.  
    }
  22.  
     
  23.  
    public static void exeSql(String sql){
  24.  
    String address = "jdbc:clickhouse://172.16.1.23:8123/default";
  25.  
    Connection connection = null;
  26.  
    Statement statement = null;
  27.  
    ResultSet results = null;
  28.  
    try {
  29.  
    Class.forName("ru.yandex.clickhouse.ClickHouseDriver");
  30.  
    connection = DriverManager.getConnection(address);
  31.  
    statement = connection.createStatement();
  32.  
    long begin = System.currentTimeMillis();
  33.  
    results = statement.executeQuery(sql);
  34.  
    long end = System.currentTimeMillis();
  35.  
    System.out.println("执行("+sql+")耗时:"+(end-begin)+"ms");
  36.  
    ResultSetMetaData rsmd = results.getMetaData();
  37.  
    List<Map> list = new ArrayList();
  38.  
    while(results.next()){
  39.  
    Map map = new HashMap();
  40.  
    for(int i = 1;i<=rsmd.getColumnCount();i++){
  41.  
    map.put(rsmd.getColumnName(i),results.getString(rsmd.getColumnName(i)));
  42.  
    }
  43.  
    list.add(map);
  44.  
    }
  45.  
    for(Map map : list){
  46.  
    System.err.println(map);
  47.  
    }
  48.  
    } catch (Exception e) {
  49.  
    e.printStackTrace();
  50.  
    }finally {//关闭连接
  51.  
    try {
  52.  
    if(results!=null){
  53.  
    results.close();
  54.  
    }
  55.  
    if(statement!=null){
  56.  
    statement.close();
  57.  
    }
  58.  
    if(connection!=null){
  59.  
    connection.close();
  60.  
    }
  61.  
    } catch (SQLException e) {
  62.  
    e.printStackTrace();
  63.  
    }
  64.  
    }
  65.  
    }
  66.  
    }

启动项目测试,发现如下报错。

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".

SLF4J: Defaulting to no-operation (NOP) logger implementation

pom引入slf4j相关文件引入依赖,并resource下添加log4j2.properties解决该问题

  1.  
    <dependency>
  2.  
    <groupId>org.apache.logging.log4j</groupId>
  3.  
    <artifactId>log4j-slf4j-impl</artifactId>
  4.  
    <version>2.11.0</version>
  5.  
    </dependency>
  • 查看输出结果
  1.  
    {name=default}
  2.  
    {name=system}
  3.  
    执行(show databases)耗时:2ms
  4.  
    {name=ontime}
  5.  
    执行(show tables)耗时:2ms
  6.  
    {name=zwqtest}
  7.  
    {name=zwqtestall}
  8.  
    执行(select count(*) count from ontime)耗时:98ms
  9.  
    {count=177920306}

使用jdbc操作ClickHouse的更多相关文章

  1. Java的JDBC操作

    Java的JDBC操作 [TOC] 1.JDBC入门 1.1.什么是JDBC JDBC从物理结构上来说就是java语言访问数据库的一套接口集合,本质上是java语言根数据库之间的协议.JDBC提供一组 ...

  2. hibernate4中使用Session doWork()方法进行jdbc操作(代码)

    Hibernate3.3.2版本中getSession().connection()已被弃用,hibernate4中官方推荐使用Session doWork()方法进行jdbc操作 首先看看Work接 ...

  3. jdbc mysql crud dao模型 sql注入漏洞 jdbc 操作大文件

    day17总结 今日内容 l JDBC 1.1 上次课内容总结 SQL语句: 1.外键约束:foreign key * 维护多个表关系! * 用来保证数据完整性! 2.三种关系: * 一对多: * 一 ...

  4. JDBC操作MySQL数据库案例

    JDBC操作MySQL数据库案例 import java.sql.Connection; import java.sql.DriverManager; import java.sql.Prepared ...

  5. JavaWeb用Jdbc操作MySql数据库(一)

    一.添加开发包.在JavaWeb中用jdbc操作数据库,使用方法与java一样,但是在处理开发包的问题上有点差别.JavaWeb不能将mysql-connector-java-5.1.7-bin.ja ...

  6. Java使用Jdbc操作MySql数据库(一)

    这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...

  7. 使用JdbcTemplate简化JDBC操作 实现数据库操作

    使用Spring JDBC框架方遍简单的完成JDBC操作,满足性能的需求且灵活性高. Spring JDBC框架由4个部分组成,即core.datasource.object.support. org ...

  8. 用于JDBC操作数据库的公共类

    /* * @(#)CommonSql.java 2011-9-5 * * Copyright 2011 Bianjing,All rights reserved. */ import java.sql ...

  9. jdbc操作mysql

    本文讲述2点: 一. jdbc 操作 MySQL .(封装一个JdbcUtils.java类,实现数据库表的增删改查) 1. 建立数据库连接 Class.forName(DRIVER); connec ...

随机推荐

  1. 关于一次同余方程的一类解法(exgcd,CRT,exCRT)

    1.解同余方程: 同余方程可以转化为不定方程,其实就是,这样的问题一般用拓展欧几里德算法求解. LL exgcd(LL a,LL b,LL &x,LL &y){ if(!b){ x=; ...

  2. git commit 合并到指定分支

    1. 将指定的commit合并到当前分支 git cherry-pick  commit_id 2. 合并多个连续 commit 到指定分支 假设需要合并 devlop 上从 fb407a3f 到 9 ...

  3. 邻居子系统 之 邻居表的初始化neigh_table_init

    概述 邻居子系统支持多种实现,例如ARP,ND等,这些实现需要在其初始化的时候,调用neigh_table_init将邻居表项添加到全局邻居子系统数组中,并对实例中的字段(如hash,定时器等)进行相 ...

  4. Linux 特殊权限

    Linux 有三个高级权限suid,sgid,sticky. 1.suid suid 属性只能运用在可执行文件上,含义是开放文件所有者的权限给其他用户,即当用户执行该执行文件时,会拥有该执行文件所有者 ...

  5. Git 推送文件到远程仓库

    Configure Git for the first time: git config --global user.name "xxxxx xx"git config --glo ...

  6. centos 6和centos7关闭防火墙的方法

    centos 6 关闭命令:  service iptables stop 永久关闭防火墙:chkconfig iptables off 两个命令同时运行,运行完成后查看防火墙关闭状态         ...

  7. 【React自制全家桶】八、React动画以及react-transition-group动画库的使用

    React动画通常有三种方法实现从易到难为: 1.transition(CSS3自带) 2.animation(CSS3自带) 3.react-transition-group动画库(需要引入插件) ...

  8. 图片加载框架之ImageLoader

    Android开发中,多少会接触到异步加载图片,或者加载大量图片的问题,而加载图片我们常常会遇到许多的问题,比如说图片的错乱,OOM等问题,对于这些问题解决起来会比较吃力,比较著名的就是Univers ...

  9. 阶段3 3.SpringMVC·_04.SpringMVC返回值类型及响应数据类型_8 响应json数据之响应json格式数据

    springMvc的框架已经帮我们做好了.发过来的数据转换为javaBean对象 发过来的键值的形式,如果属性和javaBean对应的话,可以直接封装到对象中. key做额外的转换的时候,需要另外的j ...

  10. 《Java开发手册》

    一. 编程规约 (一) 命名风格 [强制]抽象类命名使用Abstract或Base开头:异常类命名使用Exception 结尾:测试类 命名以它要测试的类的名称开始,以Test结尾. [强制]POJO ...