91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java讀取properties文件連接數據庫的方法示例

發布時間:2020-09-22 19:17:33 來源:腳本之家 閱讀:143 作者:騎豬豬看海 欄目:編程語言

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

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,用的都是這種方式,這種方式也是比較好理解的,加載驅動,帶著url,用戶名,密碼連接數據庫,代碼簡單易懂。同時也帶來了一個最重要的問題,當有一天我們想要換數據庫的時候,怎么辦?驅動也變了,什么都變了,你可以說改代碼啊,程序就是方便我們的,處理事情的方式越簡單越好,這樣更改代碼的方式很low啊,也許我們只是改了四行代碼。代碼的復用性我們可能都沒有實現。

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

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

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

Java讀取properties文件連接數據庫的方法示例

測試代碼:

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;
//  利用靜態塊i,在類加載的時候就被執行
  static{
    try {
//      用流讀入properties配置文件
      InputStream inputStream = JdbcUtil.class.getClassLoader()
          .getResourceAsStream("datebase.properties");
      Properties properties = new Properties();
//      從輸入字節流讀取屬性列表(鍵和元素對)
      properties.load(inputStream);
//      用此屬性列表中指定的鍵搜索屬性,獲取驅動,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);
//      加載驅動
      Class.forName(dirverName);
    } catch (IOException e) {
      e.printStackTrace();
    } catch (ClassNotFoundException e) {
      e.printStackTrace();
    }
 
  }
 
//  獲取數據庫連接
  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

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

北辰区| 高陵县| 驻马店市| 江山市| 怀集县| 射洪县| 称多县| 清原| 新津县| 沙坪坝区| 那曲县| 汝南县| 始兴县| 扎兰屯市| 玛多县| 志丹县| 鹤山市| 乌鲁木齐县| 定州市| 建阳市| 泰宁县| 南川市| 郁南县| 冷水江市| 秦安县| 麟游县| 西贡区| 昌都县| 安宁市| 镇平县| 长春市| 苗栗市| 洛宁县| 平陆县| 营山县| 岱山县| 夹江县| 克东县| 蒙自县| 四子王旗| 福贡县|