时间:2021-05-19
声明:
此处需求是修改封装的clickhouseUtil数据查询引擎连接工具类。由于此类中的方法都是静态方法。连接地址等参数需要根据不同环境改变。例如开发下地址,测试下地址,生产地址等,所有通过配置文件来获取不同环境下的配置参数,但是使用的方法是静态的,所有不能使用一般情况下的@value直接给变量赋值,需要用到spring 属性的set方法来给静态变量赋值,然后静态方法使用静态变量即可
方法:
第一步:在yml文件中配置需要的参数
clickhouse: address: jdbc:clickhouse://172.20.xxx.xxx:8123 username: default password: xxxxx db: marketing socketTimeout: 600000第二步:
类上一定要先注明@Component注解,在程序启动是自动加载,否则静态参数仍旧获取不到配置文件的值
创建静态变量
给静态变量set方法上添加@Value()
@Value("${clickhouse.address}") public void setClickhouseAddress(String address) { ClickHouseUtil.clickhouseAddress = address; }最后在静态方法中使用即可
@Componentpublic class ClickHouseUtil { private static String clickhouseAddress; private static String clickhouseUsername; private static String clickhousePassword; private static String clickhouseDB; private static Integer clickhouseSocketTimeout; @Value("${clickhouse.address}") public void setClickhouseAddress(String address) { ClickHouseUtil.clickhouseAddress = address; } @Value("${clickhouse.username}") public void setClickhouseUsername(String username) { ClickHouseUtil.clickhouseUsername = username; } @Value("${clickhouse.password}") public void setClickhousePassword(String password) { ClickHouseUtil.clickhousePassword = password; } @Value("${clickhouse.db}") public void setClickhouseDB(String db) { ClickHouseUtil.clickhouseDB = db; } @Value("${clickhouse.socketTimeout}") public void setClickhouseSocketTimeout(Integer socketTimeout) { ClickHouseUtil.clickhouseSocketTimeout = socketTimeout; } public static Connection getConn() { ClickHouseConnection conn = null; ClickHouseProperties properties = new ClickHouseProperties(); properties.setUser(clickhouseUsername); properties.setPassword(clickhousePassword); properties.setDatabase(clickhouseDB); properties.setSocketTimeout(clickhouseSocketTimeout); ClickHouseDataSource clickHouseDataSource = new ClickHouseDataSource(clickhouseAddress,properties); try { conn = clickHouseDataSource.getConnection(); return conn; } catch (SQLException e) { e.printStackTrace(); } return null; } public static List<JSONObject> exeSql(String sql){ log.info("cliockhouse 执行sql:" + sql); Connection connection = getConn(); try { Statement statement = connection.createStatement(); ResultSet results = statement.executeQuery(sql); ResultSetMetaData rsmd = results.getMetaData(); List<JSONObject> list = new ArrayList(); while(results.next()){ JSONObject row = new JSONObject(); for(int i = 1;i<=rsmd.getColumnCount();i++){ row.put(rsmd.getColumnName(i),results.getString(rsmd.getColumnName(i))); } list.add(row); } return list; } catch (SQLException e) { e.printStackTrace(); } return null; } }以上这篇springboot 使用yml配置文件给静态变量赋值教程就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了springboot静态变量注入配置文件的具体代码,供大家参考,具体内容如下spring静态变量注入spring中不支持直接进行静态变量值的
昨天在使用@Value注解给静态变量赋值的时候,发现静态变量的值始终是null。后来搜索一下得知其中原因,SpringBoot不允许/不支持把值注入到静态变量中
1.yml格式现在大家发现,在springboot里还是要用到配置文件的。除了使用.properties外,springboot还支持yml格式。个人觉得yml
SpringBoot中默认使用Logback进行日志输出,可以同时使用SpringBoot框架的配置文件application.yml或是通过logback的配
Springboot的默认配置文件为:application.properties或者是application.yml如果这两个配置文件都存在,不冲突的话,就互