SpringBoot基础回顾-10

3. SpringBoot数据访问

SpringData是Spring提供的一个用于简化数据库访问、支持云服务的开源框架。它是一个伞形项目,包含了大量关系型数据库及非关系型数据库的数据访问解决方案,其设计目的是使咱们能够快速且简单地使用各类数据访问技术。Spring Boot默认采用整合SpringData的方式统一处理数据访问层,经过添加大量自动配置,引入各类数据访问模板xxxTemplate以及统一的Repository接口,从而达到简化数据访问层的操做。java

Spring Data提供了多种类型数据库支持,对支持的的数据库进行了整合管理,提供了各类依赖启动器,接下来,经过一张表罗列提供的常见数据库依赖启动器,如表所示。mysql

| 名称 | 描述
|redis

| spring-boot-starter-data-jpa | 使用Spring Data
JPA与Hibernate |spring

| spring-boot-starter-data-mongodb | 使用MongoDB和Spring Data MongoDB |sql

| spring-boot-starter-data-neo4j | 使用Neo4j图数据库和Spring Data Neo4j
|mongodb

| spring-boot-starter-data-redis | 使用Redis键值数据存储与Spring Data Redis和Jedis客户端 |数据库


除此以外,还有一些框架技术,Spring Data项目并无进行统一管理, Spring Boot官方也没有提供对应的依赖启动器,可是为了迎合市场开发需求、这些框架技术开发团队本身适配了对应的依赖启动器,例如,mybatis-spring-boot-starter支持MyBatis的使用springboot

3.1 Spring Boot整合MyBatis


MyBatis 是一款优秀的持久层框架,Spring Boot官方虽然没有对MyBatis进行整合,可是MyBatis团队自行适配了对应的启动器,进一步简化了使用MyBatis进行数据的操做 mybatis


由于Spring Boot框架开发的便利性,因此实现Spring Boot与数据访问层框架(例如MyBatis)的整合很是简单,主要是引入对应的依赖启动器,并进行数据库相关参数设置便可 app

基础环境搭建

1.数据准备


在MySQL中,先建立了一个数据库springbootdata,而后建立了两个表t_article和t_comment并向表中插入数据。其中评论表t_comment的a_id与文章表t_article的主键id相关联

#
建立数据库

       CREATE
DATABASE springbootdata;

       #
选择使用数据库

      USE springbootdata;

       #
建立表t_article并插入相关数据

       DROP
TABLE IF EXISTS t_article;

      CREATE TABLE t_article (

         id int(20) NOT NULL AUTO_INCREMENT COMMENT '文章id',

         title varchar(200) DEFAULT NULL COMMENT '文章标题',

       
content longtext COMMENT '文章内容',

       
PRIMARY KEY (id)

      ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT
CHARSET=utf8;

       INSERT
INTO t_article VALUES ('1', 'Spring Boot基础入门', '从入门到精通讲解...');

       INSERT
INTO t_article VALUES ('2', 'Spring Cloud基础入门', '从入门到精通讲解...');

      # 建立表t_comment并插入相关数据

       DROP
TABLE IF EXISTS t_comment;

       CREATE
TABLE t_comment (

         id int(20) NOT NULL AUTO_INCREMENT COMMENT '评论id',

       
content longtext COMMENT '评论内容',

         author varchar(200) DEFAULT NULL COMMENT '评论做者',

         a_id int(20) DEFAULT NULL COMMENT '关联的文章id',

         PRIMARY KEY (id)

       )
ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

       INSERT
INTO t_comment VALUES ('1', '很全、很详细', 'luccy', '1');

       INSERT
INTO t_comment VALUES ('2', '赞一个', 'tom', '1');

       INSERT
INTO t_comment VALUES ('3', '很详细', 'eric', '1');

       INSERT
INTO t_comment VALUES ('4', '很好,很是详细', '张三', '1');

       INSERT
INTO t_comment VALUES ('5', '很不错', '李四', '2');

2. 建立项目,引入相应的启动器

<img
src="./images/image-20191227142727497.png"
alt="image-20191227142727497" style="zoom:67%;" />

3. 编写与数据库表t_comment和t_article对应的实体类Comment和Article

public class Comment {

             
private Integer id;

           private String content;

       private String author;

       private Integer aId;

           // 省略属性getXX()和setXX()方法

           // 省略toString()方法

}
public class Article {

 

   
private Integer id;

   
private String title;

   
private String content;

              // 省略属性getXX()和setXX()方法

          // 省略toString()方法

}

4.编写配置文件

(1)在application.properties配置文件中进行数据库链接配置

# MySQL数据库链接配置

      spring.datasource.url=jdbc:mysql://localhost:3306/springbootdata?serverTimezone=UTC

      spring.datasource.username=root

      spring.datasource.password=root

注解方式整合Mybatis

(1)建立一个用于对数据库表t_comment数据操做的接口CommentMapper

@Mapper

      public interface CommentMapper {

         
@Select("SELECT * FROM t_comment WHERE id =#{id}")

         
public Comment findById(Integer id);

      }
@Mapper注解表示该类是一个MyBatis接口文件,并保证可以被Spring Boot自动扫描到Spring容器中 

 

对应的接口类上添加了@Mapper注解,若是编写的Mapper接口过多时,须要重复为每个接口文件添加@Mapper注解

 

为了解决这种麻烦,能够直接在Spring Boot项目启动类上添加@MapperScan("xxx")注解,不须要再逐个添加

 

@Mapper注解,@MapperScan("xxx")注解的做用和@Mapper注解相似,可是它必须指定须要扫描的具体包名

(2)编写测试方法

@RunWith(SpringRunner.class)

@SpringBootTest

class SpringbootPersistenceApplicationTests
{

 

   
@Autowired

   
private CommentMapper commentMapper;

 

   
@Test

   
void contextLoads() {

       
Comment comment = commentMapper.findById(1);

       
System.out.println(comment);

    }

}

打印结果:

<img src="./images/image-20191227153811292.png"
alt="image-20191227153811292" style="zoom:67%;" />


控制台中查询的Comment的aId属性值为null,没有映射成功。这是由于编写的实体类Comment中使用了驼峰命名方式将t_comment表中的a_id字段设计成了aId属性,因此没法正确映射查询结果。

为了解决上述因为驼峰命名方式形成的表字段值没法正确映射到类属性的状况,能够在Spring
Boot全局配置文件application.properties中添加开启驼峰命名匹配映射配置,示例代码以下

#开启驼峰命名匹配映射

mybatis.configuration.map-underscore-to-camel-case=true

打印结果:

​ <img src="./images/image-20191227154947834.png"
alt="image-20191227154947834" style="zoom:67%;" />

使用配置文件的方式整合MyBatis

(1)建立一个用于对数据库表t_article数据操做的接口ArticleMapper

@Mapper

      public interface ArticleMapper {

         
public Article selectArticle(Integer id);

}

(2)建立XML映射文件


resources目录下建立一个统一管理映射文件的包mapper,并在该包下编写与ArticleMapper接口方应的映射文件ArticleMapper.xml

<?xml version="1.0"
encoding="UTF-8" ?>

       <!DOCTYPE
mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"

                   "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper
namespace="com.lagou.mapper.ArticleMapper">

   
<select id="selectArticle"
resultType="Article">

       
select * from Article

   
</select>

</mapper>

(3)配置XML映射文件路径。在项目中编写的XML映射文件,Spring Boot并没有从知晓,因此没法扫描到该自定义编写的XML配置文件,还必须在全局配置文件application.properties中添加MyBatis映射文件路径的配置,同时须要添加实体类别名映射路径,示例代码以下

#配置MyBatis的xml配置文件路径

mybatis.mapper-locations=classpath:mapper/*.xml

#配置XML映射文件中指定的实体类别名路径

mybatis.type-aliases-package=com.lagou.pojo

(4)编写单元测试进行接口方法测试

@Autowired

private ArticleMapper articleMapper;

@Test

public void selectArticle() {

       Article
article = articleMapper.selectArticle(1);

       System.out.println(article);

}

上了拉勾教育的《Java工程师高薪训练营》,作一下笔记。但愿拉勾能给我推到想去的公司,目标:字节!!

相关文章
相关标签/搜索