SpringBoot 整合 Mybatis(注解方式)|学习笔记

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 快速学习 SpringBoot 整合 Mybatis(注解方式)

开发者学堂课程【SpringBoot 实战教程  SpringBoot 整合 Mybatis(注解方式)】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/651/detail/10800


SpringBoot 整合 Mybatis(注解方式)


1、在 springboot 中利用注解的方式整合 mybatis首先需要依赖 jar 包依赖 mybatis 包和 mysql 包不用连接池直接依赖它们两个

2、创建好一个工程跟 web 进行整合写好启动类mybatis 包和 mysql 包依赖好之后配置连接数据库的信息

<!--springboot 整合 mybatis,注解版-->

<dependency>

<groupId>org.mybatis.spring.boot</groupId>

<artifactId>mybatis-spring-boot-starter</artifactId>

<version>1.3.1</version>

</dependency>

<!--MySQL-->

<dependency>

<groupId>mysql</groupId>

<artifactId>mysql-connector-java</artifactId>

</dependency>

3、创建全局配置文件命名为 application.propertiesproperties 和 yml 两个都需要会用使用 db1数据库为例

spring.datasource.driver-class-name=com.mysql.jdbc.Driver

spring.datasource.username=root

spring.datasource.password=root

spring.datasource.url=jdbc:mysql://localhost:3306/db1

4、准备好后以用户表为例在逆向工程中已经生成了 pojo准备实体类用注解的方式不需要 example把它删掉只需要留下实体类即可对应的是用户表创建一个包命名为 com.db1.mapper

5、mapper 用的是注解的方式不需要逆向工程中生成的 mapper以注解方式如何实现

6、在 UsersMapper.java 中创建一个接口写一个功能根据姓名查找用户为什么不需要 xml 配置文件在接口中对应的功能上直接写 sql 语句根据姓名查询用户对应的 sql 语句在定义接口的同时就把功能对应的 sql 语句写好了name 值如何获取相当于输入参数用 param 注解解决

package com. db1. mapper ;

import org. apache. ibatis . annotations.param;

import org . apache . ibatis . annotations . Select;

import com.db1 ·pojo.Users;

public interface User sMapper {

@Select ("select * from userswhere name=# {name }")

Users findUserByName (@Param("name") String name) ;

}

这就是用注解的方式整合 mybatis不需要 mapper.xml 配置文件这个是查找再输入添加用户只指定 name 和 password对应添加的 sql 语句输入 insert 注解进行导入只给 name 和 password 指定值values 里面需要写两个单位符输入 name 和 password 两个字段方法和对应的 sql 语句写在一起即可

@Insert ("insert intousers (name, password)values(#{name}, #{password}) )

void addUser (@Param ("name") String name, @Param ("password") String password) ;

}

7、需要生成 mapper 的代理对象扫描 mapper 即可创建 interface命名为 usersservice

8、写接口对应两个功能一个是查找用户一个是添加用户

package com. qianfeng. service;

import com.db1 .pojo. Users;

public interface UsersService {

Users findUser (String name) ;

void saveUser (Users) ;

}

9、创建 class命名为 UsersServicelmpl

10、首先加入注解Service 里面要使用 usersmapper进行注入

@Service

public class UsersServiceImpl implements UsersService {

@Autowired

private UsersMapper usersMapper;

@Override

public Users findUser (Stringname) {

return usersMapper . findUserByName (name) ; 返回的查询出的对象

}

@Override

public voidsaveUser (Users user) {  保存

usersMapper.addUser(user.getName(), user .getPassword() ) ;

}

11、创建命名为 userscontroller

import org. spr ingframework . beans . factory . annotation. Autowired;

import org . springframework. stereotype . Controller;

Importcom. qianfeng. service . UsersService;

@restController

public class UsersController {

@Autowired

Private UsersService usersService ;

@RequestMapping("/ findUser") 指定对象

//@ResponseBody  返回用户对象阶层数据即可

public Users findUser (String name )查询对象以阶层格式返回即可需要传递名字

{

return usersService. findUser (name) ;

}

@RequestMapping ("/addUser")

//@ResponseBody

public String addUser ()

{

Usersuser=new Users () ;创建 users 对象

user . setName ("王小二") ;

user . set Password("9999") ;

usersService . saveUser (user) ;

return"ok";

}

12、service 和 controller 都要被扫描mapper 也要扫描在启动类中加上扫描它会扫描它的子包mapper 要用单独的一个注解 mapperscan

@SpringBootApplication(scanBasePackages="com. qianfeng")

@MapperScan ("com. db1. mapper")

13、启动访问查找用户查找用户需要给它传递 name输入localhost:8080/findUser?name=/小红回车可以看到返回的阶层数据

image.png

14、添加功能添加王小二返回的是 users输入localhost:8080/addUser报错

image.png

15、控制台提示 sql 语句表名写错应该是 users字串是 name 和 password重新启动在表里面可以看到王小二9999添加进来

image.png

这就是 springboot 如何用注解的方式整合 mybatis

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
XML Java 数据格式
SpringBoot入门(8) - 开发中还有哪些常用注解
SpringBoot入门(8) - 开发中还有哪些常用注解
56 0
|
8天前
|
Java Spring
【Spring】方法注解@Bean,配置类扫描路径
@Bean方法注解,如何在同一个类下面定义多个Bean对象,配置扫描路径
131 73
|
3天前
|
Java Spring 容器
【SpringFramework】Spring IoC-基于注解的实现
本文主要记录基于Spring注解实现IoC容器和DI相关知识。
34 21
|
8天前
|
存储 Java Spring
【Spring】获取Bean对象需要哪些注解
@Conntroller,@Service,@Repository,@Component,@Configuration,关于Bean对象的五个常用注解
|
8天前
|
Java Spring
【Spring配置】idea编码格式导致注解汉字无法保存
问题一:对于同一个项目,我们在使用idea的过程中,使用汉字注解完后,再打开该项目,汉字变成乱码问题二:本来a项目中,汉字注解调试好了,没有乱码了,但是创建出来的新的项目,写的注解又成乱码了。
|
2月前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
1月前
|
缓存 Java 数据库连接
深入探讨:Spring与MyBatis中的连接池与缓存机制
Spring 与 MyBatis 提供了强大的连接池和缓存机制,通过合理配置和使用这些机制,可以显著提升应用的性能和可扩展性。连接池通过复用数据库连接减少了连接创建和销毁的开销,而 MyBatis 的一级缓存和二级缓存则通过缓存查询结果减少了数据库访问次数。在实际应用中,结合具体的业务需求和系统架构,优化连接池和缓存的配置,是提升系统性能的重要手段。
51 4
|
1月前
|
SQL Java 数据库连接
spring和Mybatis的各种查询
Spring 和 MyBatis 的结合使得数据访问层的开发变得更加简洁和高效。通过以上各种查询操作的详细讲解,我们可以看到 MyBatis 在处理简单查询、条件查询、分页查询、联合查询和动态 SQL 查询方面的强大功能。熟练掌握这些操作,可以极大提升开发效率和代码质量。
56 3
|
2月前
|
前端开发 Java Spring
Spring MVC核心:深入理解@RequestMapping注解
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的核心,它将HTTP请求映射到控制器的处理方法上。本文将深入探讨`@RequestMapping`注解的各个方面,包括其注解的使用方法、如何与Spring MVC的其他组件协同工作,以及在实际开发中的应用案例。
47 4
|
2月前
|
前端开发 Java 开发者
Spring MVC中的请求映射:@RequestMapping注解深度解析
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的关键,它将HTTP请求映射到相应的处理器方法上。本文将深入探讨`@RequestMapping`注解的工作原理、使用方法以及最佳实践,为开发者提供一份详尽的技术干货。
131 2