使用jdbc操作ClickHouse
使用jdbc操作ClickHouse
- 创建maven项目引入依赖
引入ClickHouse驱动包
- <dependency>
- <groupId>ru.yandex.clickhouse</groupId>
- <artifactId>clickhouse-jdbc</artifactId>
- <version>0.1.40</version>
- </dependency>
- 修改ClickHouse配置文件
vim /etc/clickhouse-server/config.xml
配置jdbc访问端口
<http_port>8123</http_port>
配置ip地址
- <listen_host>::1</listen_host>
- <listen_host>172.16.1.23</listen_host>
注:需要配置listen_host,不然会出现 Connection refused的情况,修改完成之后需要重启
- 编写测试类
- package com.zhangwq;
- import java.sql.*;
- import java.util.ArrayList;
- import java.util.HashMap;
- import java.util.List;
- import java.util.Map;
- /**
- * @author zhangwq
- * @date 2018/6/30 20:58
- */
- public class ClickHouseJDBC {
- public static void main(String[] args) {
- String sqlDB = "show databases";//查询数据库
- String sqlTab = "show tables";//查看表
- String sqlCount = "select count(*) count from ontime";//查询ontime数据量
- exeSql(sqlDB);
- exeSql(sqlTab);
- exeSql(sqlCount);
- }
- public static void exeSql(String sql){
- String address = "jdbc:clickhouse://172.16.1.23:8123/default";
- Connection connection = null;
- Statement statement = null;
- ResultSet results = null;
- try {
- Class.forName("ru.yandex.clickhouse.ClickHouseDriver");
- connection = DriverManager.getConnection(address);
- statement = connection.createStatement();
- long begin = System.currentTimeMillis();
- results = statement.executeQuery(sql);
- long end = System.currentTimeMillis();
- System.out.println("执行("+sql+")耗时:"+(end-begin)+"ms");
- ResultSetMetaData rsmd = results.getMetaData();
- List<Map> list = new ArrayList();
- while(results.next()){
- Map map = new HashMap();
- for(int i = 1;i<=rsmd.getColumnCount();i++){
- map.put(rsmd.getColumnName(i),results.getString(rsmd.getColumnName(i)));
- }
- list.add(map);
- }
- for(Map map : list){
- System.err.println(map);
- }
- } catch (Exception e) {
- e.printStackTrace();
- }finally {//关闭连接
- try {
- if(results!=null){
- results.close();
- }
- if(statement!=null){
- statement.close();
- }
- if(connection!=null){
- connection.close();
- }
- } catch (SQLException e) {
- e.printStackTrace();
- }
- }
- }
- }
启动项目测试,发现如下报错。
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
pom引入slf4j相关文件引入依赖,并resource下添加log4j2.properties解决该问题
- <dependency>
- <groupId>org.apache.logging.log4j</groupId>
- <artifactId>log4j-slf4j-impl</artifactId>
- <version>2.11.0</version>
- </dependency>
- 查看输出结果
- {name=default}
- {name=system}
- 执行(show databases)耗时:2ms
- {name=ontime}
- 执行(show tables)耗时:2ms
- {name=zwqtest}
- {name=zwqtestall}
- 执行(select count(*) count from ontime)耗时:98ms
- {count=177920306}
使用jdbc操作ClickHouse的更多相关文章
- Java的JDBC操作
Java的JDBC操作 [TOC] 1.JDBC入门 1.1.什么是JDBC JDBC从物理结构上来说就是java语言访问数据库的一套接口集合,本质上是java语言根数据库之间的协议.JDBC提供一组 ...
- hibernate4中使用Session doWork()方法进行jdbc操作(代码)
Hibernate3.3.2版本中getSession().connection()已被弃用,hibernate4中官方推荐使用Session doWork()方法进行jdbc操作 首先看看Work接 ...
- jdbc mysql crud dao模型 sql注入漏洞 jdbc 操作大文件
day17总结 今日内容 l JDBC 1.1 上次课内容总结 SQL语句: 1.外键约束:foreign key * 维护多个表关系! * 用来保证数据完整性! 2.三种关系: * 一对多: * 一 ...
- JDBC操作MySQL数据库案例
JDBC操作MySQL数据库案例 import java.sql.Connection; import java.sql.DriverManager; import java.sql.Prepared ...
- JavaWeb用Jdbc操作MySql数据库(一)
一.添加开发包.在JavaWeb中用jdbc操作数据库,使用方法与java一样,但是在处理开发包的问题上有点差别.JavaWeb不能将mysql-connector-java-5.1.7-bin.ja ...
- Java使用Jdbc操作MySql数据库(一)
这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...
- 使用JdbcTemplate简化JDBC操作 实现数据库操作
使用Spring JDBC框架方遍简单的完成JDBC操作,满足性能的需求且灵活性高. Spring JDBC框架由4个部分组成,即core.datasource.object.support. org ...
- 用于JDBC操作数据库的公共类
/* * @(#)CommonSql.java 2011-9-5 * * Copyright 2011 Bianjing,All rights reserved. */ import java.sql ...
- jdbc操作mysql
本文讲述2点: 一. jdbc 操作 MySQL .(封装一个JdbcUtils.java类,实现数据库表的增删改查) 1. 建立数据库连接 Class.forName(DRIVER); connec ...
随机推荐
- JavaScript数字计算精度丢失的问题和解决方案
一.JS数字精度丢失的一些典型问题 1. 两个简单的浮点数相加:0.1 + 0.2 != 0.3 // true,下图是firebug的控制台截图: 看看java的计算结果:是不是让你很不能接受 再来 ...
- koa 基础(二十五)数据库 与 art-template 模板 联动 --- 新增数据
1.视图层 根目录/views/index.html <!DOCTYPE html> <html lang="en"> <head> <m ...
- 提问(prompt)
prompt弹出消息对话框,通常用于询问一些需要与用户交互的信息.弹出消息对话框(包含一个确定按钮.取消按钮与一个文本输入框). 语法: prompt(str1, str2); 参数说明: str1: ...
- 警告(alert)、确认(confirm)
我们在访问网站的时候,有时会突然弹出一个小窗口,上面写着一段提示信息文字.如果你不点击“确定”,就不能对网页做任何操作,这个小窗口就是使用alert实现的. 语法: alert(字符串或变量);注:a ...
- vue问题六:表单验证
表单验证规则 查看文档:https://blog.csdn.net/weixin_42018790/article/details/80762149 1). el-form增加 :rules=&quo ...
- 1、WebSphere Application Server的下载以及安装
最近在做农行相关的项目,我们的后台需要发布到农行WebSphere Application Server上,因此学习一下: 一.WebSphere 是什么? WebSphere 为 SOA (面向服务 ...
- OGG-00446 分析与解决
OGG-00446 分析与解决 Table of Contents 1. 00446 1.1. Missing filename opening checkpoint file 1.1.1. 错误信息 ...
- Redis集群配置和常见异常解决
前文 Redis的Cluster集群,是在分布式且开源环境下最佳的高可用解决方案,可以有效的解决服务器宕机下或高并发下,数据的完整性. 文档前提 Redis 3.0版本或更高版本.(3.0版本开始支持 ...
- idea中git远程版本回退
idea中git远程版本回退 2017年10月15日 15:25:36 gomeplus 阅读数:19313 工作中遇到git远程仓库需要回退到历史版本的问题,根据网上的搜索结果结合自己的实践,整理了 ...
- 性能测试之JMeter远程模式
性能测试之JMeter远程模式 事实上,你的JMeter客户端机器是不能表现出完美的压力请求,来模拟足够多的用户或由于网络限制去向服务施加压力,一种解决方法是通过一个JMeter去控制多个/远程JMe ...