ClickHouse数据库之JDBC篇

标签: Clickhouse 分类: 数据库 创建时间:2019-12-24 08:52:55 更新时间:2025-01-17 10:39:22

上一篇讲了如何使用SpringBoot+Druid+MyBatis连接和查询ClickHouse数据库( ClickHouse数据库之Java篇 ),这一篇说一说如何使用JDBC的方式直接连接数据库,其实和MyBatis差不多。

1.引入依赖包

我这里使用了clickhouse4j,而不是官方提供的。

1
2
3
4
5
<dependency>
<groupId>cc.blynk.clickhouse</groupId>
<artifactId>clickhouse4j</artifactId>
<version>1.4.2</version>
</dependency>

2.编写代码

接下来编写代码就完事了,简单。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
package com.bibichuan.bigdata.Clickhouse;

import org.springframework.stereotype.Component;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

@Component
public class ClickhouseDbUtil {
public static final String URL = "jdbc:clickhouse://192.168.1.90:8123/lsmfhx";
public static final String USER = "admin";
public static final String PASSWORD = "1q2w3e4r.";

public Connection coon=null;

public ClickhouseDbUtil(){
try{
//1.加载驱动程序
Class.forName("cc.blynk.clickhouse.ClickHouseDriver");
//2. 获得数据库连接
this.coon = DriverManager.getConnection(URL, USER, PASSWORD);
//3.操作数据库,实现增删改查
Statement stmt = this.coon.createStatement();

ResultSet rs = stmt.executeQuery("SELECT * FROM realtime where id=443");
//如果有数据,rs.next()返回true
while(rs.next()){
System.out.println(rs.getString("SiteNo")+" 年龄:"+rs.getInt("Alarm"));
}
}catch (Exception e){
System.out.println(e);
}
}
// 执行sql语句
public ResultSet executeSql(String sql){
ResultSet resultSet=null;
try{
Statement stmt = this.coon.createStatement();

resultSet = stmt.executeQuery(sql);

}catch (Exception e){
System.out.println(e);
}
return resultSet;

}
}

参考文章:
1.JDBC 使用说明
小额赞助
本人提供免费与付费咨询服务,感谢您的支持!赞助请发邮件通知,方便公布您的善意!
**光 3.01 元
Sun 3.00 元
bibichuan 3.00 元
微信公众号
广告位
诚心邀请广大金主爸爸洽谈合作
每日一省
isNaN 和 Number.isNaN 函数的区别?

1.函数 isNaN 接收参数后,会尝试将这个参数转换为数值,任何不能被转换为数值的的值都会返回 true,因此非数字值传入也会返回 true ,会影响 NaN 的判断。

2.函数 Number.isNaN 会首先判断传入参数是否为数字,如果是数字再继续判断是否为 NaN ,不会进行数据类型的转换,这种方法对于 NaN 的判断更为准确。

每日二省
为什么0.1+0.2 ! == 0.3,如何让其相等?

一个直接的解决方法就是设置一个误差范围,通常称为“机器精度”。对JavaScript来说,这个值通常为2-52,在ES6中,提供了Number.EPSILON属性,而它的值就是2-52,只要判断0.1+0.2-0.3是否小于Number.EPSILON,如果小于,就可以判断为0.1+0.2 ===0.3。

每日三省
== 操作符的强制类型转换规则?

1.首先会判断两者类型是否**相同,**相同的话就比较两者的大小。

2.类型不相同的话,就会进行类型转换。

3.会先判断是否在对比 null 和 undefined,是的话就会返回 true。

4.判断两者类型是否为 string 和 number,是的话就会将字符串转换为 number。

5.判断其中一方是否为 boolean,是的话就会把 boolean 转为 number 再进行判断。

6.判断其中一方是否为 object 且另一方为 string、number 或者 symbol,是的话就会把 object 转为原始类型再进行判断。

每日英语
Happiness is time precipitation, smile is the lonely sad.
幸福是年华的沉淀,微笑是寂寞的悲伤。