DynamicDataSourceFactory.java 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /**
  2. * Copyright (c) 2018 yiidata.com All rights reserved.
  3. *
  4. * http://yiidata.com
  5. *
  6. *
  7. */
  8. package com.yiidata.intergration.web.datasource.config;
  9. import com.alibaba.druid.pool.DruidDataSource;
  10. import com.yiidata.intergration.web.datasource.properties.DataSourceProperties;
  11. import java.sql.SQLException;
  12. /**
  13. * DruidDataSource
  14. *
  15. * @author zhenqin
  16. * @since 1.0.0
  17. */
  18. public class DynamicDataSourceFactory {
  19. public static DruidDataSource buildDruidDataSource(DataSourceProperties properties) {
  20. DruidDataSource druidDataSource = new DruidDataSource();
  21. druidDataSource.setDriverClassName(properties.getDriverClassName());
  22. druidDataSource.setUrl(properties.getUrl());
  23. druidDataSource.setUsername(properties.getUsername());
  24. druidDataSource.setPassword(properties.getPassword());
  25. druidDataSource.setInitialSize(properties.getInitialSize());
  26. druidDataSource.setMaxActive(properties.getMaxActive());
  27. druidDataSource.setMinIdle(properties.getMinIdle());
  28. druidDataSource.setMaxWait(properties.getMaxWait());
  29. druidDataSource.setTimeBetweenEvictionRunsMillis(properties.getTimeBetweenEvictionRunsMillis());
  30. druidDataSource.setMinEvictableIdleTimeMillis(properties.getMinEvictableIdleTimeMillis());
  31. druidDataSource.setMaxEvictableIdleTimeMillis(properties.getMaxEvictableIdleTimeMillis());
  32. druidDataSource.setValidationQuery(properties.getValidationQuery());
  33. druidDataSource.setValidationQueryTimeout(properties.getValidationQueryTimeout());
  34. druidDataSource.setTestOnBorrow(properties.isTestOnBorrow());
  35. druidDataSource.setTestOnReturn(properties.isTestOnReturn());
  36. druidDataSource.setPoolPreparedStatements(properties.isPoolPreparedStatements());
  37. druidDataSource.setMaxOpenPreparedStatements(properties.getMaxOpenPreparedStatements());
  38. druidDataSource.setSharePreparedStatements(properties.isSharePreparedStatements());
  39. try {
  40. druidDataSource.setFilters(properties.getFilters());
  41. druidDataSource.init();
  42. } catch (SQLException e) {
  43. e.printStackTrace();
  44. }
  45. return druidDataSource;
  46. }
  47. }