成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Java讀取properties文件連接數(shù)據庫

xeblog / 3313人閱讀

摘要:我們定義好一個配置文件,讓程序來讀取這個文件,這個程序是固定的,只是配置文件我們自己來寫,這樣做的好處就是,我們在更改數(shù)據庫的時候,不需要更改代碼,提高了代碼的復用性。下圖是連接時候需要的信息我的數(shù)據庫是,和都是,讀者根據自己的數(shù)據庫來寫。

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

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,用戶名,密碼連接數(shù)據庫,代碼簡單易懂。同時也帶來了一個最重要的問題,當有一天我們想要換數(shù)據庫的時候,怎么辦?驅動也變了,什么都變了,你可以說改代碼啊,程序就是方便我們的,處理事情的方式越簡單越好,這樣更改代碼的方式很low啊,也許我們只是改了四行代碼。代碼的復用性我們可能都沒有實現(xiàn)。
我們定義好一個配置文件,讓程序來讀取這個文件,這個程序是固定的,只是配置文件我們自己來寫,這樣做的好處就是,我
們在更改數(shù)據庫的時候,不需要更改代碼,提高了代碼的復用性。
先介紹一下propertie文件: Java中的properties文件是一種配置文件,主要用于表達配置信息,文件類型為*.properties,格式為文本文件,文件的內容是格式是 "鍵=值"的格式。

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

測試代碼:

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);
//            用此屬性列表中指定的鍵搜索屬性,獲取驅動,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();
        }
 
    }
 
//    獲取數(shù)據庫連接
    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ù)據庫的時候只要把properties文件中的值更改了就可以,代碼是不需要修改的,因為jdbc是固定的。在其他的配置方面也可以使用這種方法,提高了代碼的復用性

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/74108.html

相關文章

  • Java編程基礎33——JDBC

    摘要:是訪問數(shù)據庫的標準規(guī)范提供了一種基準據此可以構建更高級的工具和接口,使數(shù)據庫開發(fā)人員能夠編寫數(shù)據庫應用程序。在將此值發(fā)送到數(shù)據庫時,驅動程序將它轉換成一個類型值。 1.JDBC概念和數(shù)據庫驅動程序 A: JDBC概述 JDBC(Java Data Base Connectivity,java數(shù)據庫連接)是一種用于執(zhí)行SQL語句的Java API,可以為多種關系數(shù)據庫提供統(tǒng)一訪問,...

    KitorinZero 評論0 收藏0
  • 1、JDBC 2、DBUtils

    摘要:是訪問數(shù)據庫的標準規(guī)范提供了一種基準據此可以構建更高級的工具和接口,使數(shù)據庫開發(fā)人員能夠編寫數(shù)據庫應用程序。在將此值發(fā)送到數(shù)據庫時,驅動程序將它轉換成一個類型值。例如值不支持中文,如果需要使用非英文字符,將進行轉換。 01JDBC概念和數(shù)據庫驅動程序 * A: JDBC概念和數(shù)據庫驅動程序 * a: JDBC概述 * JDBC(Java Data...

    galaxy_robot 評論0 收藏0
  • Hibernate配置及自定義注冊映射文件

    摘要:一配置屬性詳解可以在各式各樣不同環(huán)境下工作而設計的因此存在著大量的配置參數(shù)。以簡便操作,多數(shù)配置參數(shù)都有默認的配置值也是我們日常使用的必須品。 Hibernate (開放源代碼的對象關系映射框架) Hibernate是一個開放源代碼的對象關系映射框架,它對JDBC進行了非常輕量級的對象封裝, 它將POJO與數(shù)據庫表建立映射關系,是一個全自動的orm框架,hibernat...

    coordinate35 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<