Spring单数据源的配置详解
目录
- 前言
- 一、生成项目骨架(SpringBoot),运行一个简单的程序
- 二、选择原生Spring方式配置数据源
前言 spring数据源的配置网络上有很多例子,这里我也来介绍一下单数据源配置的例子,基于SpringBoot的方式和原生的Spring的方式。
【Spring单数据源的配置详解】
一、生成项目骨架(SpringBoot),运行一个简单的程序 访问:https://start.spring.io/ ,选择必要的依赖
文章图片
下面我们先看下Application类的代码:
@SpringBootApplication@Slf4jpublic class SpringDatasourceApplication implements CommandLineRunner { @Autowired private DataSource dataSource; @Autowired private JdbcTemplate jdbcTemplate; public static void main(String[] args) {SpringApplication.run(SpringDatasourceApplication.class, args); } @Override public void run(String... args) throws Exception {showConnection(); showData(); } private void showConnection() throws SQLException {log.info("数据源:"+dataSource.toString()); Connection conn = dataSource.getConnection(); log.info("连接:"+conn.toString()); conn.close(); } private void showData() {jdbcTemplate.queryForList("SELECT * FROM user").forEach(row -> log.info("记录:"+row.toString())); }}
application.properties文件的配置项,我们可以看到我们使用的h2数据库
management.endpoints.web.exposure.include=*spring.output.ansi.enabled=ALWAYSspring.datasource.url=jdbc:h2:mem:demodbspring.datasource.username=saspring.datasource.password=
在资源文件目录,写入两个文件,一个是data.sql、一个是schema.sql
文章图片
schema.sql内容是:
CREATE TABLE user (ID INT IDENTITY, name VARCHAR(64),age INT);
data.sql内容是:
INSERT INTO user (ID,name,age) VALUES (1, '张三',18); INSERT INTO user (ID, name,age) VALUES (2, '李四',19);
运行代码,结果如下:
文章图片
其实我们并没有去对DataSource进行bean配置,只是指定了数据库的类型,加载了建表语句和初始化数据语句,可以看到连接池是Hikari,这也是springboot默认的连接池。
由于是使用的内置数据库,我们可以在代码中
这也是因为springboot给我们自动装配了我们所需要的信息,由于我们引入了actuator,我们可以通过http://localhost:8080/actuator/beans 看到springboot帮我们装载了很多的bean,有些可能是我们根本用不到的。下面我们讲一下原生Spring方式怎么实现配置数据源。
二、选择原生Spring方式配置数据源 pom文件配置内容:
org.springframework spring-context${spring.version} org.springframework spring-jdbc${spring.version} org.apache.commons commons-dbcp22.8.0 ```**创建applicationContext.xml文件,内容如下:**```xml com.h2database h21.4.200 runtime
** 自定义DataSource,这里使用注解来实现(使用dbcp连接池) **
@Configuration@EnableTransactionManagementpublic class DataSourceDemo {@Autowiredprivate DataSource dataSource; public static void main(String[] args) throws SQLException {ApplicationContext applicationContext =new ClassPathXmlApplicationContext("applicationContext*.xml"); showBeans(applicationContext); dataSourceDemo(applicationContext); }@Bean(destroyMethod = "close")public DataSource dataSource() throws Exception {Properties properties = new Properties(); properties.setProperty("driverClassName", "org.h2.Driver"); properties.setProperty("url", "jdbc:h2:mem:testdb"); properties.setProperty("username", "sa"); return BasicDataSourceFactory.createDataSource(properties); }@Beanpublic PlatformTransactionManager transactionManager() throws Exception {return new DataSourceTransactionManager(dataSource()); }private static void showBeans(ApplicationContext applicationContext) {System.out.println(Arrays.toString(applicationContext.getBeanDefinitionNames())); }private static void dataSourceDemo(ApplicationContext applicationContext) throws SQLException {DataSourceDemo demo = applicationContext.getBean("dataSourceDemo", DataSourceDemo.class); demo.showDataSource(); }public void showDataSource() throws SQLException {System.out.println(dataSource.toString()); Connection conn = dataSource.getConnection(); System.out.println(conn.toString()); conn.close(); }}
运行main方法:
文章图片
可以看到可以实现和springboot一样的效果
- 通过上面的两个例子,我们可以看出SpringBoot帮我们实现了如下功能:
- 通过DataSourceAutoConfiguration 配置 DataSource
- 通过DataSourceTransactionManagerAutoConfiguration 配置 DataSourceTransactionManager
- 通过JdbcTemplateAutoConfiguration 配置 JdbcTemplate
在实际情况下,我们可能需要在应用中配置多个数据源,下篇文章我将介绍多个数据源的配置方式。
到此这篇关于Spring单数据源的配置详解的文章就介绍到这了,更多相关Spring单数据源的配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- Activiti(一)SpringBoot2集成Activiti6
- 科学养胃,别被忽悠,其实真的很简单
- SpringBoot调用公共模块的自定义注解失效的解决
- opencv|opencv C++模板匹配的简单实现
- 解决SpringBoot引用别的模块无法注入的问题
- 单点登陆
- 松软可口易消化,无需烤箱超简单,新手麻麻也能轻松成功~
- 友情的开始
- 【读书清单20】写作吧!你值得被看见(2)
- 2018-07-09|2018-07-09 Spring 的DBCP,c3p0