Java读取properties文件连接数据库的方法示例

作者:骑猪猪看海 时间:2024-01-13 15:17:24 

之前我们在入门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是固定的。在其他的配置方面也可以使用这种方法,提高了代码的复用性

来源:https://segmentfault.com/a/1190000018881348

标签:Java,properties,连接数据库
0
投稿

猜你喜欢

  • MySQL 5.5主从同步设置笔记分享

    2024-01-27 10:12:29
  • python ddt实现数据驱动

    2021-11-11 02:37:08
  • 解决django后台样式丢失,css资源加载失败的问题

    2021-05-21 13:00:38
  • 解析:在SQL Server下数据库链接的使用

    2009-01-23 13:37:00
  • python实现LBP方法提取图像纹理特征实现分类的步骤

    2023-05-24 02:12:27
  • Vue提供的三种调试方式你知道吗

    2024-05-29 22:44:57
  • bak文件怎么打开 2000w数据怎么打开?

    2024-01-12 19:30:43
  • Go interface接口声明实现及作用详解

    2024-05-21 10:22:48
  • 利用python爬取散文网的文章实例教程

    2023-06-17 10:40:18
  • 使用Python手工计算x的算数平方根,来自中国古人的数学智慧

    2021-12-07 01:29:53
  • 如何使用Python处理HDF格式数据及可视化问题

    2023-11-21 00:17:01
  • DreamweaverMX2004技巧两则

    2010-09-05 21:10:00
  • 分析与比较五种MySQL数据库可靠性方案

    2009-07-30 08:25:00
  • mysql数据库索引损坏及修复经验分享

    2024-01-16 11:22:43
  • Python3使用腾讯云文字识别(腾讯OCR)提取图片中的文字内容实例详解

    2023-11-16 22:45:05
  • Js nodeType 属性全面解析

    2024-04-16 09:53:30
  • tensorflow实现残差网络方式(mnist数据集)

    2023-08-10 08:33:31
  • vue3中关于路由hash与History的设置

    2024-05-13 09:14:24
  • python小程序之飘落的银杏

    2023-05-25 02:58:31
  • 9种python web 程序的部署方式小结

    2021-04-14 10:39:44
  • asp之家 网络编程 m.aspxhome.com