登录
首页 >  数据库 >  MySQL

Mybatis-配置和整合

来源:SegmentFault

时间:2023-02-24 14:52:16 166浏览 收藏

来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习数据库相关编程知识。下面本篇文章就来带大家聊聊《Mybatis-配置和整合》,介绍一下MySQL、Java、数据库、jdbc、mybatis,希望对大家的知识积累有所帮助,助力实战开发!

正文

一. Mybatis工程搭建

1. 创库建表

首先创建一个名为test

CREATE TABLE book(
    id INT(11) PRIMARY KEY AUTO_INCREMENT,
    b_name VARCHAR(255) NOT NULL,
    b_price FLOAT NOT NULL
)

然后往book表插入三条数据,插入语句如下所示。

INSERT INTO book (b_name, b_price) VALUES ("Math", 20.5)
INSERT INTO book (b_name, b_price) VALUES ("English", 21.5)
INSERT INTO book (b_name, b_price) VALUES ("Water Margin", 30.5)

上述数据用于

org.mybatisMyBatis XML配置,里面有关于

@Data
public class Book {

    private long id;
    private String bookName;
    private float bookPrice;

}

5. 映射接口和映射文件

由于在

public interface BookMapper {

    List selectAllBooks();

}

映射文件

由于maven默认不会将src/main/java下的非

src/main/java**/*.xmlfalse

6. 工程结构

整个工程结构如下所示。

其中

public class MybatisTest {

    public static void main(String[] args) throws Exception {
        String resource = "mybatis-config.xml";
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder()
                .build(Resources.getResourceAsStream(resource));
        SqlSession sqlSession = sqlSessionFactory.openSession();
        BookMapper bookMapper = sqlSession.getMapper(BookMapper.class);
        List books = bookMapper.selectAllBooks();
        books.forEach(book -> System.out.println(book.toString()));
    }

}

这里特别注意

org.mybatis.spring.bootmybatis-spring-boot-starter2.1.3

最后测试时采用基于rest工具调用接口的方式来触发对数据库的操作,因此还需要引入web依赖,如下所示。

org.springframework.bootspring-boot-starter-web2.4.1

在使用了

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/test?characterEncoding=utf-8&serverTimezone=UTC&useSSL=false
    username: root
    password: root

mybatis:
  configuration:
    use-generated-keys: true

本节中,映射接口

@SpringBootApplication
@MapperScan("com.mybatis.learn.dao")
public class MybatisLearnApplication {

    public static void main(String[] args) {
        SpringApplication.run(MybatisLearnApplication.class, args);
    }

}

至此整合已经结束,整个工程结构如下所示。

service层和controller层用于测试。

@Service
public class MybatisService {

    @Autowired
    private BookMapper bookMapper;

    public List selectAllBooks() {
        return bookMapper.selectAllBooks();
    }

}

在成功完成整合之后,可以从

@RestController
public class MybatisController {

    @Autowired
    private MybatisService mybatisService;

    @RequestMapping(value = "/api/v1/selectall", method = RequestMethod.GET)
    public ResponseEntity> selectAllBooks() {
        List books;
        try {
            books = mybatisService.selectAllBooks();
        } catch (Exception e) {
            return new ResponseEntity(null, HttpStatus.INTERNAL_SERVER_ERROR);
        }
        return new ResponseEntity(books, HttpStatus.OK);
    }

}

最后基于rest工具调用接口,结果如下所示。

总结

本篇文章介绍了如何在一个

Maven
工程中通过引入
Mybatis
依赖包来搭建一个连接数据库的测试工程,然后对Springboot整合
Mybatis
进行了案例演示,无论哪种方式,通过
Mybatis
操作数据库都相较于传统
JDBC
方式具有更方便更强大的特性。

以上就是《Mybatis-配置和整合》的详细内容,更多关于mysql的资料请关注golang学习网公众号!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表