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

Java讀取properties文件連接數(shù)據(jù)庫的方法示例

 更新時間:2019年04月16日 11:40:36   作者:騎豬豬看海  
這篇文章主要介紹了Java讀取properties文件連接數(shù)據(jù)庫的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

之前我們在入門jdbc的時候,常用這種方法連接數(shù)據(jù)庫:

package util;
 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
 
public class ConnectionManager {
  public static Connection getConnection() {
    Connection conn = null;
    try {
      Class.forName("com.mysql.jdbc.Driver");
      String url = "jdbc:mysql://localhost:3306/mail";
      String username = "root";
      String password = "root";
      conn = DriverManager.getConnection(url, username, password);
    } catch (ClassNotFoundException e1) {
      e1.printStackTrace();
    } catch (SQLException e) {
      e.printStackTrace();
    }
    return conn;
  }
 
}

相信剛接觸jdbc,用的都是這種方式,這種方式也是比較好理解的,加載驅(qū)動,帶著url,用戶名,密碼連接數(shù)據(jù)庫,代碼簡單易懂。同時也帶來了一個最重要的問題,當(dāng)有一天我們想要換數(shù)據(jù)庫的時候,怎么辦?驅(qū)動也變了,什么都變了,你可以說改代碼啊,程序就是方便我們的,處理事情的方式越簡單越好,這樣更改代碼的方式很low啊,也許我們只是改了四行代碼。代碼的復(fù)用性我們可能都沒有實現(xiàn)。

我們定義好一個配置文件,讓程序來讀取這個文件,這個程序是固定的,只是配置文件我們自己來寫,這樣做的好處就是,我
們在更改數(shù)據(jù)庫的時候,不需要更改代碼,提高了代碼的復(fù)用性。

先介紹一下propertie文件: Java中的properties文件是一種配置文件,主要用于表達(dá)配置信息,文件類型為*.properties,格式為文本文件,文件的內(nèi)容是格式是 "鍵=值"的格式。

可以理解為Map結(jié)構(gòu),鍵值對的方式存儲,可以根據(jù)鍵來找到值。下圖是java連接mysql時候需要的信息(我的數(shù)據(jù)庫是mail,username和password都是root,讀者根據(jù)自己的數(shù)據(jù)庫來寫)。一個鍵對應(yīng)一個值,用=連接。

測試代碼:

package util;
 
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;
 
public class JdbcUtil {
  private static String dirverName;
  private static String url;
  private static String username;
  private static String password;
//  利用靜態(tài)塊i,在類加載的時候就被執(zhí)行
  static{
    try {
//      用流讀入properties配置文件
      InputStream inputStream = JdbcUtil.class.getClassLoader()
          .getResourceAsStream("datebase.properties");
      Properties properties = new Properties();
//      從輸入字節(jié)流讀取屬性列表(鍵和元素對)
      properties.load(inputStream);
//      用此屬性列表中指定的鍵搜索屬性,獲取驅(qū)動,url,username,password
      dirverName = properties.getProperty("driverName");
      url = properties.getProperty("url");
      username = properties.getProperty("username");
      password = properties.getProperty("password");
      System.out.println(dirverName);
      System.out.println(url);
      System.out.println(username);
      System.out.println(password);
//      加載驅(qū)動
      Class.forName(dirverName);
    } catch (IOException e) {
      e.printStackTrace();
    } catch (ClassNotFoundException e) {
      e.printStackTrace();
    }
 
  }
 
//  獲取數(shù)據(jù)庫連接
  public static Connection getConnection() {
    Connection conn=null;
    try {
      conn=DriverManager.getConnection(url, username, password);
    } catch (SQLException e) {
      e.printStackTrace();
    }
    return conn;
  }
  
//測試
  public static void main(String[] args) {
    JdbcUtil.getConnection();
  }
}

輸出:

com.mysql.jdbc.Driver
jdbc:mysql://localhost:3306/mail
root
root

這樣做,我們在想要換數(shù)據(jù)庫的時候只要把properties文件中的值更改了就可以,代碼是不需要修改的,因為jdbc是固定的。在其他的配置方面也可以使用這種方法,提高了代碼的復(fù)用性

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • spring強(qiáng)行注入和引用實例解析

    spring強(qiáng)行注入和引用實例解析

    這篇文章主要介紹了spring強(qiáng)行注入和引用實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-09-09
  • Java長字符串加密的實現(xiàn)

    Java長字符串加密的實現(xiàn)

    在Java中,字符串是一種常見的數(shù)據(jù)類型,我們經(jīng)常需要對其進(jìn)行加密和解密,本文主要介紹了Java長字符串加密的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • Java實現(xiàn)終止線程池中正在運(yùn)行的定時任務(wù)

    Java實現(xiàn)終止線程池中正在運(yùn)行的定時任務(wù)

    本篇文章給大家分享了JAVA中實現(xiàn)終止線程池中正在運(yùn)行的定時任務(wù)的具體步驟和方法,有需要的朋友跟著學(xué)習(xí)下。
    2018-05-05
  • javaNIO中關(guān)于ByteBuffer的用法

    javaNIO中關(guān)于ByteBuffer的用法

    這篇文章主要介紹了javaNIO中關(guān)于ByteBuffer的用法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • SpringMVC日期類型接收空值異常問題解決方法

    SpringMVC日期類型接收空值異常問題解決方法

    這篇文章主要介紹了SpringMVC日期類型接收空值異常問題解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • SpringBoot整合Thymeleaf小項目及詳細(xì)流程

    SpringBoot整合Thymeleaf小項目及詳細(xì)流程

    這篇文章主要介紹了SpringBoot整合Thymeleaf小項目,本項目使用SpringBoot開發(fā),jdbc5.1.48,主要涉及到Mybatis的使用,Thymeleaf的使用,用戶密碼加密,驗證碼的設(shè)計,圖片的文件上傳(本文件上傳到本地,沒有傳到數(shù)據(jù)庫)登錄過濾,需要的朋友可以參考下
    2022-03-03
  • 詳解Java8與Runtime.getRuntime().availableProcessors()

    詳解Java8與Runtime.getRuntime().availableProcessors()

    這篇文章主要介紹了詳解Java8與Runtime.getRuntime().availableProcessors(),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Java編程—在測試中考慮多態(tài)

    Java編程—在測試中考慮多態(tài)

    這篇文章主要介紹了Java編程—在測試中考慮多態(tài),具有一定參考價值,需要的朋友可以了解下。
    2017-11-11
  • springboot 設(shè)置CorsFilter跨域不生效的解決

    springboot 設(shè)置CorsFilter跨域不生效的解決

    這篇文章主要介紹了springboot 設(shè)置CorsFilter跨域不生效的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • druid ParserException類錯誤問題及解決

    druid ParserException類錯誤問題及解決

    這篇文章主要介紹了druid ParserException類錯誤問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12

最新評論