SpringBoot2.0 基础案例(06):引入JdbcTemplate,和多数据源配置

匿名 (未验证) 提交于 2019-12-02 21:40:30

在Spring Boot2.0框架下配置数据源和通过JdbcTemplate访问数据库的案例。
SpringBoot对数据库的操作在jdbc上面做了深层次的封装,使用spring的注入功能,可以把DataSource注册到JdbcTemplate之中。

1)execute方法:可以用于执行任何SQL语句; 2)update方法batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句; 3)query方法及queryFor方法:用于执行查询相关语句; 4)call方法:用于执行存储过程、函数相关语句。
<!-- 数据库依赖 --> <dependency>     <groupId>mysql</groupId>     <artifactId>mysql-connector-java</artifactId>     <version>5.1.21</version> </dependency> <!-- JDBC 依赖 --> <dependency>     <groupId>org.springframework.boot</groupId>     <artifactId>spring-boot-starter-jdbc</artifactId> </dependency>
spring:   application:     # 应用名称     name: node06-boot-jdbc   datasource:     # 数据源一:data_one 库     primary:       # 2.0开始的版本必须这样配置       jdbc-url: jdbc:mysql://localhost:3306/data_one       #url: jdbc:mysql://localhost:3306/data_one       username: root       password: 123       driver-class-name: com.mysql.jdbc.Driver     # 数据源二:data_two 库     secondary:       # 2.0开始的版本必须这样配置       jdbc-url: jdbc:mysql://localhost:3306/data_two       #url: jdbc:mysql://localhost:3306/data_two       username: root       password: 123       driver-class-name: com.mysql.jdbc.Driver

1)数据源一的配置
@Primary 注解表示该数据源作为默认的主数据库。

/**  * 数据源一配置  */ @Configuration public class DataOneConfig {      @Primary    // 主数据库     @Bean(name = "primaryDataSource")     @Qualifier("primaryDataSource")     @ConfigurationProperties(prefix = "spring.datasource.primary")     public DataSource primaryDataSource (){         return DataSourceBuilder.create().build() ;     }      @Bean(name = "primaryJdbcTemplate")     public JdbcTemplate primaryJdbcTemplate (             @Qualifier("primaryDataSource") DataSource dataSource){         return new JdbcTemplate(dataSource);     } }

2)数据源二配置

/**  * 数据源二配置  */ @Configuration public class DataTwoConfig {     @Bean(name = "secondaryDataSource")     @Qualifier("secondaryDataSource")     @ConfigurationProperties(prefix="spring.datasource.secondary")     public DataSource secondaryDataSource() {         return DataSourceBuilder.create().build();     }      @Bean(name = "secondaryJdbcTemplate")     public JdbcTemplate secondaryJdbcTemplate(             @Qualifier("secondaryDataSource") DataSource dataSource) {         return new JdbcTemplate(dataSource);     } }
@RestController public class JdbcController {     private static final Logger LOG = LoggerFactory.getLogger(JdbcController.class);      // 数据源一     @Autowired     @Qualifier("primaryJdbcTemplate")     private JdbcTemplate primaryJdbcTemplate ;      // 数据源二     @Autowired     @Qualifier("secondaryJdbcTemplate")     private JdbcTemplate secondaryJdbcTemplate ;      /**      * 多数据源查询      */     @RequestMapping("/queryData")     public String queryData (){         String sql = "SELECT COUNT(1) FROM d_phone" ;         Integer countOne = primaryJdbcTemplate.queryForObject(sql,Integer.class) ;         Integer countTwo = secondaryJdbcTemplate.queryForObject(sql,Integer.class) ;         LOG.info("countOne=="+countOne+";;countTwo=="+countTwo);         return "SUCCESS" ;     } }
GitHub地址:知了一笑 https://github.com/cicadasmile/spring-boot-base 码云地址:知了一笑 https://gitee.com/cicadasmile/spring-boot-base


易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!