Spring Boot 集成数据库

(一)操作数据库

1.在pom.xml中引入相关的依赖

        <!-- 添加对jdbc 的依赖 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>

        <!-- 添加数据库驱动 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>

2.在application.properties 全局配置文件中设置数据库的相关配置

spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/springboot
spring.datasource.username=root
spring.datasource.password=1234

3.测试代码(入口类)

/** 入口类 */
@SpringBootApplication(scanBasePackages = "com.jas")
public class SpringbootApplication {    
    public static void main(String[] args) throws Exception{

        ConfigurableApplicationContext context = SpringApplication.run(SpringbootApplication.class, args);

        System.out.println(context.getBean(DataSource.class).getClass());
        System.out.println(context.getBean(DataSource.class).getConnection());

    }
}

控制台输出

class org.apache.tomcat.jdbc.pool.DataSource
ProxyConnection[PooledConnection[com.mysql.jdbc.JDBC4Connection@511505e7]]

从上面的输出可以看出Spring Boot 默认使用的是tomcat 的数据源。

(二)自定义数据源

这里我们以c3p0 数据源为例,有两种配置数据源的方式,分别是:在全局配置文件中进行设置与使用配置类。

2.1在全局配置文件中配置

1.首先在pom.xml 中引入c3p0 的依赖

    <!-- 添加c3p0 数据源的依赖 -->
    <dependency>
        <groupId>c3p0</groupId>
        <artifactId>c3p0</artifactId>
        <version>0.9.1.2</version>
    </dependency>

2.在application.properties 中配置数据库信息与c3p0 数据源

spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/springboot
spring.datasource.username=root
spring.datasource.password=1234

spring.datasource.type=com.mchange.v2.c3p0.ComboPooledDataSource

启动入口类控制台输出

class com.mchange.v2.c3p0.ComboPooledDataSource
com.mchange.v2.c3p0.impl.NewProxyConnection@64d43929

2.2使用配置类

1.在pom.xml 中引入c3p0 的依赖
2.在application.properties 中配置数据库信息,也可以写一个配置文件单独封装这些信息

spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/springboot
spring.datasource.username=root
spring.datasource.password=1234

3.配置类

@SpringBootConfiguration
public class DatasourceConfiguration {

    /**
     * environment 用于读取`application.properties` 配置文件中的配置信息
     */
    @Autowired
    private Environment environment;

    @Bean
    public DataSource createDataSource() throws Exception {
        ComboPooledDataSource dataSource = new ComboPooledDataSource();

        dataSource.setDriverClass(environment.getProperty("spring.datasource.driver-class-name"));
        dataSource.setJdbcUrl(environment.getProperty("spring.datasource.url"));
        dataSource.setUser(environment.getProperty("spring.datasource.username"));
        dataSource.setPassword(environment.getProperty("spring.datasource.password"));

        return dataSource;
    }    
}

(三)事务管理

在Spring Boot 中使用事务,需要在入口类中使用@EnableTransactionManagement注解启用事务。
对需要进行事务管理的方法加上@Transactional注解。

PS:需要注意的是 @Transactional 注解默认只会对运行时异常(RuntimeException)起作用,对于I/O 等其他异常不起作用。对于其他方式的异常,Spring Boot 在@Transactional 注解中提供了rollbackFornoRollbackFor 选项,可以让我们自定义对异常的回滚。

    /**
     * rollbackFor 设置回滚的异常,Exception 可以回滚所有的异常,
     * noRollbackFor 设置不回滚事务的异常
     */
    `@Transactional `(rollbackFor = Exception.class, noRollbackFor = NullPointerException.class )

另一个地方需要注意的是:在同一个类中一个没有设置注解的方法调用有注解的方法时,事务不生效。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值