欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot 使用yml配置文件給靜態(tài)變量賦值教程

 更新時(shí)間:2020年04月26日 09:29:39   作者:Alice_qixin  
這篇文章主要介紹了springboot 使用yml配置文件給靜態(tài)變量賦值教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lá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)文章

  • Maven deploy配置方法詳解

    Maven deploy配置方法詳解

    這篇文章主要介紹了Maven deploy配置方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 使用mybatis插件PageHelper實(shí)現(xiàn)分頁(yè)效果

    使用mybatis插件PageHelper實(shí)現(xiàn)分頁(yè)效果

    這篇文章主要為大家詳細(xì)介紹了使用mybatis插件PageHelper實(shí)現(xiàn)分頁(yè)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • Spring?Boot統(tǒng)一接口返回及全局異常處理

    Spring?Boot統(tǒng)一接口返回及全局異常處理

    這篇文章主要介紹了Spring?Boot統(tǒng)一接口返回及全局異常處理,文章圍繞主題展開相關(guān)資料,具有一定的參考價(jià)值需要的小伙伴可以參考一下
    2022-04-04
  • 使用Java實(shí)現(xiàn)百萬(wàn)Excel數(shù)據(jù)導(dǎo)出

    使用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-03
  • MyBatis直接執(zhí)行SQL的工具SqlMapper

    MyBatis直接執(zhí)行SQL的工具SqlMapper

    今天小編就為大家分享一篇關(guān)于MyBatis直接執(zhí)行SQL的工具SqlMapper,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-12-12
  • SpringBoot返回long,前端接收進(jìn)度丟失,@JsonSerialize不生效問題

    SpringBoot返回long,前端接收進(jìn)度丟失,@JsonSerialize不生效問題

    這篇文章主要介紹了SpringBoot返回long,前端接收進(jìn)度丟失,@JsonSerialize不生效問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • IDEA actiBPM插件安裝圖文教程

    IDEA actiBPM插件安裝圖文教程

    這篇文章主要介紹了IDEA actiBPM插件安裝教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • 流式圖表拒絕增刪改查之kafka核心消費(fèi)邏輯下篇

    流式圖表拒絕增刪改查之kafka核心消費(fèi)邏輯下篇

    這篇文章主要為大家介紹了流式圖表拒絕增刪改查之kafka核心消費(fèi)邏輯講解的下篇,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • Spring?@Bean注解深入分析源碼執(zhí)行過(guò)程

    Spring?@Bean注解深入分析源碼執(zhí)行過(guò)程

    隨著SpringBoot的流行,我們現(xiàn)在更多采用基于注解式的配置從而替換掉了基于XML的配置,所以本篇文章我們主要探討基于注解的@Bean以及和其他注解的使用
    2023-01-01
  • java實(shí)現(xiàn)超市管理系統(tǒng)

    java實(shí)現(xiàn)超市管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)超市管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12

最新評(píng)論