mysql 读取properties_Java读取properties文件连接数据库

本文介绍了如何在Java中使用properties文件存储数据库连接信息,以提高代码复用性和简化数据库更换过程。通过加载配置文件,程序能动态获取数据库驱动、URL、用户名和密码,避免直接在代码中硬编码这些敏感信息。
摘要由CSDN通过智能技术生成

之前我们在入门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,读者根据自己的数据库来写)。一个键对应一个值,用=连接。

0cb1c2f70a0819a506f7954b50b13333.png

测试代码:

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值