springboot 使用yml配置文件給靜態(tài)變量賦值教程
聲明:
此處需求是修改封裝的clickhouseUtil數(shù)據(jù)查詢引擎連接工具類。由于此類中的方法都是靜態(tài)方法。連接地址等參數(shù)需要根據(jù)不同環(huán)境改變。例如開發(fā)下地址,測(cè)試下地址,生產(chǎn)地址等,所有通過(guò)配置文件來(lái)獲取不同環(huán)境下的配置參數(shù),但是使用的方法是靜態(tài)的,所有不能使用一般情況下的@value直接給變量賦值,需要用到spring 屬性的set方法來(lái)給靜態(tài)變量賦值,然后靜態(tài)方法使用靜態(tài)變量即可
方法:
第一步:在yml文件中配置需要的參數(shù)
clickhouse: address: jdbc:clickhouse://172.20.xxx.xxx:8123 username: default password: xxxxx db: marketing socketTimeout: 600000
第二步:
類上一定要先注明@Component注解,在程序啟動(dòng)是自動(dòng)加載,否則靜態(tài)參數(shù)仍舊獲取不到配置文件的值
創(chuàng)建靜態(tài)變量
給靜態(tài)變量set方法上添加@Value()
@Value("${clickhouse.address}") public void setClickhouseAddress(String address) { ClickHouseUtil.clickhouseAddress = address; }
最后在靜態(tài)方法中使用即可
@Component public 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 執(zhí)行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配置文件給靜態(tài)變量賦值教程就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用mybatis插件PageHelper實(shí)現(xiàn)分頁(yè)效果
這篇文章主要為大家詳細(xì)介紹了使用mybatis插件PageHelper實(shí)現(xiàn)分頁(yè)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01Spring?Boot統(tǒng)一接口返回及全局異常處理
這篇文章主要介紹了Spring?Boot統(tǒng)一接口返回及全局異常處理,文章圍繞主題展開相關(guān)資料,具有一定的參考價(jià)值需要的小伙伴可以參考一下2022-04-04使用Java實(shí)現(xiàn)百萬(wàn)Excel數(shù)據(jù)導(dǎo)出
這篇文章主要為大家詳細(xì)介紹了如何使用Java實(shí)現(xiàn)百萬(wàn)Excel數(shù)據(jù)導(dǎo)出,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,有需要的小伙伴可以參考一下2024-03-03MyBatis直接執(zhí)行SQL的工具SqlMapper
今天小編就為大家分享一篇關(guān)于MyBatis直接執(zhí)行SQL的工具SqlMapper,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-12-12SpringBoot返回long,前端接收進(jìn)度丟失,@JsonSerialize不生效問題
這篇文章主要介紹了SpringBoot返回long,前端接收進(jìn)度丟失,@JsonSerialize不生效問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08Spring?@Bean注解深入分析源碼執(zhí)行過(guò)程
隨著SpringBoot的流行,我們現(xiàn)在更多采用基于注解式的配置從而替換掉了基于XML的配置,所以本篇文章我們主要探討基于注解的@Bean以及和其他注解的使用2023-01-01