Java读取properties文件连接数据库
来源:互联网 发布:单片机一键信号发射 编辑:程序博客网 时间:2024/06/04 19:06
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文件的类Properties,包括加载,读取这些操作都已经定义好,我们只是调用即可
下面是利用工具类读取properties文件,利用了static静态块,properties配置文件下载了src文件夹下,在写路径的时候注意一下
代码部分引用了http://blog.csdn.net/u013805360/article/details/45692495的
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是固定的。在其他的配置方面也可以使用这种方法,提高了代码的复用性
//—————————————————分隔线——————————————————————//
说一下在这里的掉进的坑,找了好长时间,一直报着类找不到
配置文件中的信息都已经读取到了,也是正确的,jar包也在,把jar删了重新导入也不行……再看看properties配置文件恍然大悟……
怎么Driver的后面怎么不一样,鼠标点上去,两个空格!!!,把这两个空格删了,正常运行没有抛异常,由于是字符串中也是可以
有空格的所以读取到的驱动后面都是带两个空格的,哪里有后面带两个空格的驱动啊……
建议把之前的代码读取配置文件属性的方法最后加上trim()方法去掉空格
dirverName = properties.getProperty("driverName").trim();url = properties.getProperty("url").trim();username = properties.getProperty("username").trim();password = properties.getProperty("password").trim();
- Java系列-读取properties文件连接数据库
- Java读取properties文件连接数据库
- 读取properties文件连接数据库
- 读取配置jdbc.properties文件连接数据库
- java读取properties文件,通过数据池(BasicDataSource)连接mysql数据库
- 通过读取properties文件动态生成对数据库的连接
- Java读取Properties文件
- java读取.properties文件
- java读取.properties文件
- Java读取properties文件
- Java读取properties文件
- java读取properties文件
- java读取properties文件
- java读取properties文件
- java读取properties文件
- java 读取properties文件
- java 读取 properties 文件
- java读取properties文件
- C语言练习题(2)
- android手机客户端测试体系
- MarkDown基本语法
- 1411矩阵取数问题V3
- 简单banner加载网络上的图片
- Java读取properties文件连接数据库
- linux 测试是否能访问端口
- JAVA之Set筛选字符元素
- 1701H2 10.25 王建瑜 连续第二天
- BitMap 二次采样工具类
- [Flink]Flink1.3 Stream指南五 窗口触发器与驱逐器
- 【高维前缀和】SPOJ(TLE)[Time Limit Exceeded]题解
- 同步、异步、阻塞和非阻塞的概念
- java中的快速生成代码