美文网首页Java 杂谈
Java读取properties文件连接数据库

Java读取properties文件连接数据库

作者: Web前端学习营 | 来源:发表于2019-04-25 18:53 被阅读0次

    之前我们在入门jdbc的时候,常用这种方法连接数据库:

    packageutil;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.SQLException;publicclassConnectionManager{publicstaticConnectiongetConnection(){        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();        }returnconn;    } }

    相信刚接触jdbc,用的都是这种方式,这种方式也是比较好理解的,加载驱动,带着url,用户名,密码连接数据库,代码简单易懂。同时也带来了一个最重要的问题,当有一天我们想要换数据库的时候,怎么办?驱动也变了,什么都变了,你可以说改代码啊,程序就是方便我们的,处理事情的方式越简单越好,这样更改代码的方式很low啊,也许我们只是改了四行代码。代码的复用性我们可能都没有实现。

    哦对了,在分享这篇文字前,我先说一下,我这里有一份Java学习资料,直接加我的Java直播学习群:1004944760就能免费领取,长期真实有效。

    我们定义好一个配置文件,让程序来读取这个文件,这个程序是固定的,只是配置文件我们自己来写,这样做的好处就是,我

    们在更改数据库的时候,不需要更改代码,提高了代码的复用性。

    先介绍一下propertie文件: Java中的properties文件是一种配置文件,主要用于表达配置信息,文件类型为*.properties,格式为文本文件,文件的内容是格式是 "键=值"的格式。

    可以理解为Map结构,键值对的方式存储,可以根据键来找到值。下图是java连接mysql时候需要的信息(我的数据库是mail,username和password都是root,读者根据自己的数据库来写)。一个键对应一个值,用=连接。

    测试代码:

    package util;importjava.io.IOException;importjava.io.InputStream;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.SQLException;importjava.util.Properties;publicclassJdbcUtil{privatestaticStringdirverName;privatestaticStringurl;privatestaticStringusername;privatestaticStringpassword;//    利用静态块i,在类加载的时候就被执行static{try{//            用流读入properties配置文件InputStreaminputStream =JdbcUtil.class.getClassLoader()                    .getResourceAsStream("datebase.properties");Propertiesproperties = newProperties();//            从输入字节流读取属性列表(键和元素对)properties.load(inputStream);//            用此属性列表中指定的键搜索属性,获取驱动,url,username,passworddirverName = 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(IOExceptione) {            e.printStackTrace();        }catch(ClassNotFoundExceptione) {            e.printStackTrace();        }    }//    获取数据库连接publicstaticConnectiongetConnection() {Connectionconn=null;try{            conn=DriverManager.getConnection(url, username, password);        }catch(SQLExceptione) {            e.printStackTrace();        }returnconn;    }//测试publicstaticvoid main(String[] args) {JdbcUtil.getConnection();    }}

    输出:

    com.mysql.jdbc.Driverjdbc:mysql://localhost:3306/mailrootroot

    这样做,我们在想要换数据库的时候只要把properties文件中的值更改了就可以,代码是不需要修改的,因为jdbc是固定的。在其他的配置方面也可以使用这种方法,提高了代码的复用性

    相关文章

      网友评论

        本文标题:Java读取properties文件连接数据库

        本文链接:https://www.haomeiwen.com/subject/btctnqtx.html