【springboot】19、数据库操作

有时候,不是因为你没有能力,也不是因为你缺少勇气,只是因为你付出的努力还太少,所以,成功便不会走向你。而你所需要做的,就是坚定你的梦想,你的目标,你的未来,然后以不达目的誓不罢休的那股劲,去付出你的努力,成功就会慢慢向你靠近。

导读:本篇文章讲解 【springboot】19、数据库操作,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

基本说明

这篇文章介绍如何在springboot的项目中进行数据库的连接,完成数据库操作。

默认数据源HikariDataSource

HikariDataSource是springboot的默认数据源,性能十分优秀,我们如果想要进行数据库操作,需要引入相应的starter

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jdbc</artifactId>
        </dependency>

在这个starter里面就有关于HikariDataSource的引入

在这里插入图片描述

Spring Boot 不知道项目要操作 Mysql 还是 Oracle,或者是其他数据库 ,所以需要在 pom.xml 指定导入数据库驱动

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.49</version>
        </dependency>

接下来就是配置数据库的基本信息了,我们在配置文件yaml中进行配置,数据库的配置信息是基于DataSourceProperties这个类的
在这里插入图片描述

下面就是该类的一些字段

在这里插入图片描述

我们需要配置的就4个,就是用户名,密码,驱动类名和url

在这里插入图片描述

把这些配置完成之后我们就可以直接使用了,我们使用JdbcTemplate来测试一下
下面是我创建的一张表,里面有3条信息,现在就是要使用JdbcTemplate完成该表的查询

在这里插入图片描述

测试代码如下

@Data
public class People {
    private Integer id;
    private String name;
    private String gender;
    private Integer age;
}
@SpringBootTest
public class ApplicationTest {

    @Resource
    private JdbcTemplate jdbcTemplate;

    @Test
    public void t1() {
        BeanPropertyRowMapper<People> rowMapper = new BeanPropertyRowMapper<>(People.class);
        String sql = "select * from people";
        List<People> peopleList = jdbcTemplate.query(sql, rowMapper);
        System.out.println("\n----------------start----------------");
        System.out.println(Objects.requireNonNull(jdbcTemplate.getDataSource()).getClass());
        for (People people : peopleList) {
            System.out.println(people);
        }
        System.out.println("-----------------end-----------------\n");

    }
}

运行代码,查看控制台输出
在这里插入图片描述
可以发现已经完成了查询,也就是说明数据库的连接已经没有问题了。还可以看见我们springboot使用的默认数据源确实是HikariDataSource。

切换数据源为Druid

上面我们使用的是默认数据源,这里我就来介绍如何进行切换,以Druid为例子,首先我们现需要引入druid的相关依赖

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.2.15</version>
        </dependency>

然后创建一个配置类,在这个类里面注入一个DruidDataSource

@Configuration
public class DruidConfig {

    @ConfigurationProperties("spring.datasource")
    @Bean
    public DataSource dataSource(){
        return new DruidDataSource();
    }
}

@ConfigurationProperties(“spring.datasource”)这行代码的意思就是DruidDataSource要去读取配置文件中关于spring.datasource信息,配置文件内容如下
在这里插入图片描述
这样配置之后,我们的数据源就已经是Druid了,还是运行上面的测试代码,查看控制台输出
在这里插入图片描述
可以发现数据源已经切换为Druid了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/146267.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!