springboot 手动创建datasource的方式

builder

在这里插入图片描述

 @Bean
  public DataSource getDataSource() {
    DataSourceBuilder dataSourceBuilder = DataSourceBuilder.create();
    dataSourceBuilder.driverClassName("org.h2.Driver");
    dataSourceBuilder.url("jdbc:h2:mem:test");
    dataSourceBuilder.username("SA");
    dataSourceBuilder.password("");
    return dataSourceBuilder.build();

DriverManagerDataSource

 @Bean(name = "dataSource")
    public DataSource dataSource() {
 
        DriverManagerDataSource dataSource = new DriverManagerDataSource();
        dataSource.setDriverClassName(driverClass);
        dataSource.setUrl(url);
        dataSource.setUsername(userName);
        dataSource.setPassword(passWord);
        return dataSource;
    }

spring自动配置autoconfig

@AutoWired
DataSource datasource

硬编码:

调用构造函数
源码:

   public HikariDataSource()
   {
      super();
      fastPathPool = null;
   }
 public HikariDataSource(HikariConfig configuration)
   {
      configuration.validate();
      configuration.copyStateTo(this);

      LOGGER.info("{} - Starting...", configuration.getPoolName());
      pool = fastPathPool = new HikariPool(this);
      LOGGER.info("{} - Start completed.", configuration.getPoolName());

      this.seal();
   }

Tomcat 数据源配置

<Resource name="jdbc/OracleHikari" auth="Container"
      factory="com.zaxxer.hikari.HikariJNDIFactory"
      type="javax.sql.DataSource"
      minimumIdle="5" 
      maximumPoolSize="10"
      connectionTimeout="300000"
      dataSourceClassName="oracle.jdbc.pool.OracleDataSource"
      dataSource.implicitCachingEnabled="true" 
      dataSource.user="user"
      dataSource.password="pwd"
      dataSource.url="jdbc:oracle:thin:@orcl_server:1521:orcl"/>
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring Boot中的DataSource工具类是用于配置和管理数据库连接的类。它可以帮助我们简化数据库连接的配置,提供连接池功能,以及管理数据库事务。 在Spring Boot中,我们通常使用Spring的JdbcTemplate来操作数据库。JdbcTemplate需要一个DataSource对象作为参数,用于获取数据库连接。因此,我们需要配置一个DataSource对象,并将其注入到JdbcTemplate中。 在配置DataSource时,我们可以使用Spring Boot提供的自动配置功能,也可以通过编写自定义配置类来手动配置。自动配置功能会根据我们的依赖和配置文件中的属性自动创建和配置DataSource对象。 下面是一个使用自动配置功能的示例: ```java @SpringBootApplication public class MyApp { public static void main(String[] args) { SpringApplication.run(MyApp.class, args); } @Autowired private JdbcTemplate jdbcTemplate; // 使用JdbcTemplate进行数据库操作 public void doSomething() { String sql = "SELECT * FROM users"; List<User> users = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class)); // ... } } ``` 在上面的示例中,我们通过@Autowired注解将JdbcTemplate对象注入到了MyApp类中。Spring Boot会自动根据配置文件中的属性创建DataSource对象,并将其注入到JdbcTemplate中。 除了自动配置外,我们还可以通过编写自定义配置类来手动配置DataSource。例如: ```java @Configuration public class DataSourceConfig { @Value("${spring.datasource.url}") private String url; @Value("${spring.datasource.username}") private String username; @Value("${spring.datasource.password}") private String password; @Value("${spring.datasource.driver-class-name}") private String driverClassName; @Bean public DataSource dataSource() { DriverManagerDataSource dataSource = new DriverManagerDataSource(); dataSource.setUrl(url); dataSource.setUsername(username); dataSource.setPassword(password); dataSource.setDriverClassName(driverClassName); return dataSource; } } ``` 在上面的示例中,我们通过@Configuration注解将该类标记为配置类,并使用@Bean注解将dataSource方法声明为一个Bean。方法中的代码会创建一个DriverManagerDataSource对象,并设置相关属性。 这只是DataSource工具类的简单示例,实际应用中可能还需要配置连接池、事务管理等功能。不同的数据库连接池和事务管理器可能有不同的配置方式,请根据具体情况进行配置。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值