一、采用读取数据源配置文件的方式
package com.ofsp.utils;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;
public class DataSourceUtil {
     public static final String DATASOURCE_FILENAME ="jdbc.properties"; //连接数据库的数据源文件
     public static final String DATASOURCE_URL = "jdbc.url"; //数据源文件里url的key
     public static final String DATASOURCE_USERNAME = "jdbc.username";//数据源文件里用户名的key
     public static final String DATASOURCE_PASSWORD = "jdbc.password";//数据源文件里密码的key
 
     /**
      * 读取配置文件信息
      * @return Properties 配置文件信息
      * @throws Exception
      */
     public static Properties getProperties() throws Exception {
         InputStream in = null;
         if (in == null) {
             //Class.getResourceAsStream() 会指定要加载的资源路径与当前类所在包的路径一致。例如你写了一个MyTest类在包com.test.mycode 下,那么MyTest.class.getResourceAsStream("name") 会在com.test.mycode包下查找相应的资源。如果这个name是以 '/' 开头的,那么就会从classpath的根路径下开始查找。 ClassLoader.getResourceAsStream()  无论要查找的资源前面是否带'/' 都会从classpath的根路径下查找。
             in = Thread.currentThread().getContextClassLoader().getResourceAsStream(DATASOURCE_FILENAME); //路径是 classpath的相对路径, classpath是指 WEB-INF文件夹下的classes目录
             if(in == null){
                 throw new Exception("找不到路径为"+DATASOURCE_FILENAME+"的数据源配置文件。");
             }
         }
         Properties properties = new Properties();
         try {
             properties.load(in);
         } catch (IOException e) {
             e.printStackTrace();
         }
         return properties;
     }
 
     /**
      * 读取配置文件获取连接数据库的数据库url
      * @return String 数据库名
      * @throws Exception
      */
     public static String getDatabaseURL() throws Exception {
          Properties p = getProperties();
          return p.getProperty(DATASOURCE_URL);
     }
 
     /**
      * 读取配置文件获取连接数据库的用户名
      * @return String 用户名
     * @throws Exception
      */
     public static String getUserOfDatabase() throws Exception {
          Properties p = getProperties();
          return p.getProperty(DATASOURCE_USERNAME);
     }
 
     /**
      * 读取配置文件获取连接数据库的密码
      * @return String 密码
     * @throws Exception
      */
     public static String getPasswordOfDatabase() throws Exception {
          Properties p = getProperties();
          return p.getProperty(DATASOURCE_PASSWORD);
     }
 
     /**
      * 获取数据库Connection
      * @return
      * @throws Exception
      */
     public static Connection getConnection() throws Exception{
         Properties p = getProperties();
         String url = p.getProperty(DATASOURCE_URL);
         String username = p.getProperty(DATASOURCE_USERNAME);
         String password = p.getProperty(DATASOURCE_PASSWORD);
         return DriverManager.getConnection(url, username, password);
     }
 
     /**
      * 获取指定数据库和用户的所有表名
      * @param conn 连接数据库对象
      * @param user 用户
      * @param database 数据库名
      * @return
      */
     public static List<String> getAllTableNames(Connection conn,String database,String schem,String tableName) {
         List<String> tableNames = new ArrayList<String>();
         if (conn != null) {
               try {
                    DatabaseMetaData metadata = conn.getMetaData();
                    // 表名列表
                    ResultSet rest = metadata.getTables(database, schem.toUpperCase(), tableName.toUpperCase(), new String[] {"TABLE"});
                    while (rest.next()) {
                        tableNames.add(rest.getString("TABLE_NAME"));
                    }
               } catch (SQLException e) {
                   e.printStackTrace();
               }
          }
          return tableNames;
     }
 
}
二、如果采用Spring框架的话,还可以从Spring的配置文件中获取当前数据源:
数据源文件配置在spring-context.xml文件中,部分片断截取:
DruidDataSource dataSource = ApplicationContextHelper.getBean("dataSource");//获取数据源
Connection connection = dataSource.getConnection();//获取连接
String user = dataSource.getUsername();//获取用户名
注意:connection用完后一定要及时close掉,否则会出现溢出错误。

Java读取数据源相关信息的更多相关文章

  1. java读取properties配置文件信息

    一.Java Properties类 Java中有个比较重要的类Properties(Java.util.Properties),主要用于读取Java的配置文件,各种语言都有自己所支持的配置文件,配置 ...

  2. Java读取图片exif信息实现图片方向自动纠正

    起因 一个对试卷进行OCR识别需求,需要实现一个功能,一个章节下的题目图片需要上下拼接合成一张大图,起初写了一个工具实现图片的合并,程序一直很稳定的运行着,有一反馈合成的图片方向不对,起初怀疑是本身图 ...

  3. Java读取txt文件信息并操作。

    一.java读取txt文件内容 import java.io.BufferedInputStream; import java.io.BufferedReader; import java.io.Fi ...

  4. fstat - 读取文件相关信息

    #fstat读取到的信息 ["dev"]=> int(16777220) ["ino"]=> int(66880002) ["mode&q ...

  5. Java用System读取系统相关信息、环境变量——(六)

    package Java_Test; public class System1 { public static void main(String[] args) { // TODO Auto-gene ...

  6. (转)java读取数据库表信息,子段

    import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sq ...

  7. java 读取数据库中文信息,为何在jsp页面中出现乱码

    有如下几种解决办法:1.保证项目的字符编码和每一个jsp页面的字符编码一致,如果不一致可能导致中文乱码问题<%@ page language="java" contentTy ...

  8. java读取配置文件的信息

    1. 首先,工程结构如下: 注:a. 蓝色标注的两个文件是和com包平级的,都在src下.EnnNotificationPushProxy.ini是这个工程的配置文件,log4j.properties ...

  9. JAVA获取系统相关信息

    Version:0.9 StartHTML:-1 EndHTML:-1 StartFragment:00000099 EndFragment:00003596 获取JRE系统相关参数 java 通过S ...

随机推荐

  1. tomcat类加载体系

    类加载,再来一发. 研究完java提供的类加载机制,再来看看tomcat开出了那些花. 最近开始读tomcat的源码,主线路当然是类加载机制,在这个过程中有豁然开朗的感觉.这一篇主要是自己的体会,而不 ...

  2. 我来说说XML文件中的xmlns、xmlns:xsi和xsi:schemaLocation的具体含义

      文章摘自:https://yq.aliyun.com/articles/40353               http://www.cnblogs.com/zhao1949/p/5652167. ...

  3. Cornerstone 3.0.3 for mac 破解版

    破解版本 直接安装即可 解压密码:xclient.info 下载地址: 链接: https://pan.baidu.com/s/1mhD64vY 密码: nwmc

  4. 互联网金融P2P主业务场景自动化测试

            互联网金融P2P行业,近三年来发展迅速,如火如荼.         据不完全统计,全国有3000+的企业.  “互联网+”企业,几乎每天都会碰到一些奇奇怪怪的bug,作为在互联网企业工 ...

  5. java虚拟机学习-JVM调优总结-典型配置举例(10)

    以下配置主要针对分代垃圾回收算法而言. 堆大小设置 年轻代的设置很关键 JVM中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制:系统的可用虚拟内存限制:系统的可用物理 ...

  6. Python正则表达式完全指南(上)

    正则表达式处理文本有如疾风扫秋叶,绝大部分编程语言都内置支持正则表达式,它应用在诸如表单验证.文本提取.替换等场景.爬虫系统更是离不开正则表达式,用好正则表达式往往能收到事半功倍的效果. 介绍正则表达 ...

  7. nodejs服务实现反向代理,解决本地开发接口请求跨域问题

    前后端分离项目需要解决第一个问题就是,前端本地开发时如何解决通过ajax请求产生的跨域的问题.一般的做法是通过本地配置nginx反向代理进行处理的,除此之外,还可以通过nodejs来进行代理接口.当然 ...

  8. gradle windows 环境变量

    我的电脑 ->  高级环境变量 GRADLE_HOME    D:\soft\gradle-3.5 path %GRADLE_HOME%\bin

  9. Spring学习笔记——02 Bean的命名及实例化

    一.Bean的命名 前一篇讲到IoC是一个管理Bean的容器,Bean多数情况下都是通过XML文件进行配置的,其中Bean的命名有以下几种方式,现在梳理一下. 1. 不指定id,只配置类名 <b ...

  10. 【T-SQL进阶】02.理解SQL查询的底层原理

    本系列[T-SQL]主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础]02.联接查询 [T-SQL基础]03.子查询 [T-SQL基础]04.表表达式 ...