JDBCUtil.java 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. package com.sf.sysdemo.util;
  2. import com.alibaba.druid.pool.DruidDataSourceFactory;
  3. import javax.sql.DataSource;
  4. import java.io.IOException;
  5. import java.io.InputStream;
  6. import java.sql.Connection;
  7. import java.sql.SQLException;
  8. import java.util.Properties;
  9. // 工具类
  10. public class JDBCUtil {
  11. // 提供一个静态的数据源
  12. private static DataSource dataSource;
  13. // 静态初始化块
  14. static {
  15. Properties properties = new Properties();
  16. // 获得类加载器
  17. ClassLoader classLoader = JDBCUtil.class.getClassLoader();
  18. // 加载指定配置文件 获取输入流
  19. InputStream inputStream = classLoader.getResourceAsStream("jdbc.properties");
  20. try {
  21. // 将输入流加载进 properties对象中
  22. properties.load(inputStream);
  23. } catch (IOException e) {
  24. throw new RuntimeException(e);
  25. }
  26. // 通过druid提供的工厂类 来创建出数据源
  27. try {
  28. dataSource = DruidDataSourceFactory.createDataSource(properties);
  29. } catch (Exception e) {
  30. throw new RuntimeException(e);
  31. }
  32. }
  33. // 提供数据源
  34. public static DataSource getDataSource() {
  35. return dataSource;
  36. }
  37. // 提供数据库的连接
  38. public static Connection getConnection(){
  39. try {
  40. Connection connection = dataSource.getConnection();
  41. return connection;
  42. } catch (SQLException e) {
  43. throw new RuntimeException(e);
  44. }
  45. }
  46. }