返回顶部
首页 > 资讯 > 后端开发 > Python >SpringBoot框架整合Mybatis简单攻略
  • 701
分享到

SpringBoot框架整合Mybatis简单攻略

2024-04-02 19:04:59 701人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录步骤 1 添加mybatis-starter依赖步骤 2 如何配置mybatis到SpringBoot项目步骤 3 测试查询步骤 4 mybatis注解方式步骤 5 用注解方式做

步骤 1 添加mybatis-starter依赖

访问:https://mvnrepository.com/

搜索mybatis,找到 MyBatis Spring Boot Starter ,点进去,复制到pom.xml


<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.2.0</version>
</dependency>

我们就用最新的即可。

步骤 2 如何配置mybatis到SpringBoot项目


mybatis:
  mapper-locations: classpath:mybatis/*.xml
  type-aliases-package: com.java18.vipmgr.pojo

mapper-locations是定义xml文件所在的目录。

在这里插入图片描述

我们放在resources下面,也就是classpath中。

UserMapper.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.java18.vipmgr.mapper.UserMapper">
    <select id="getAllUsers" resultType="User">
        select * from users
    </select>
</mapper>

里面就写了一个方法,注意 namespace=“com.java18.vipmgr.mapper.UserMapper” 这个配置。这个表示该xml文件是和UserMapper.java绑定的。

在这里插入图片描述

代码如下


@Mapper
public interface UserMapper {
    public List<User> getAllUsers();
}

接下来再看 resultType=“User” 这个配置,为什么返回类型知道是User对象呢?

User类在这:

在这里插入图片描述


@Data
public class User {
    private Integer id;
    private String username;
    private String passWord;
    private Integer points;
}

那是因为,我们在application.yml中做了绑定,也就是这个:


mybatis:
  mapper-locations: classpath:mybatis/*.xml
  <font color="#c24f4a">type-aliases-package: com.java18.vipmgr.pojo</font>

所以,当我们写 resultType=“User” 的时候,就会自动匹配到com.java18.vipmgr.pojo包下面的User类。

至此,配置mybatis到SpringBoot项目就成功了!

步骤 3 测试查询

在这里插入图片描述

还是在controller中做测试,首先引入Mapper


@Autowired
UserMapper userMapper;

然后编写查询方法


@GetMapping("getAllViaMybatis")
public  List<User> getAllViaMybatis(){
    return userMapper.getAllUsers();
}

启动服务,访问http://localhost:8888/user/getAllViaMybatis,得

[{“id”:1,“username”:“zhangsan”,“password”:“123”,“points”:1000},{“id”:2,“username”:“lisi”,“password”:“123”,“points”:200}]

步骤 4 mybatis注解方式

除了xml的方式,我们还可以使用mybatis注解方式
UserMapper.java


@Mapper
public interface UserMapper {
    public List<User> getAllUsers();
​
    @Select("select * from users where id = #{param1}")
    User findById(String id);
​
}

增加了一个方法,打了@Select注解,接收ID为参数,这边用的是mybatis的顺序传参法。

对应的Controller方法


@GetMapping("findById")
public  User findById(String id){
    return userMapper.findById(id);
}

测试url:http://localhost:8888/user/findById?id=2

返回 {“id”:2,“username”:“lisi”,“password”:“123”,“points”:200}

这种的好处就是不用写xml了,很方便,缺点是不够灵活。

步骤 5 用注解方式做一个新增操作

mapper代码


@Update("insert into users values (null,#{username},#{password},#{points})")
void addUser(User user);

controller代码


@GetMapping("addUser")
public  boolean addUser(){
    User user = new User();
    user.setUsername("wangwu");
    user.setPassword("123");
    user.setPoints(1000);
    userMapper.addUser(user);
    return true;
}

测试效果

在这里插入图片描述

PS: 因为id是自动增长的,所以插入null即可。

步骤 6 整合PageHelper分页插件

pom.xml


<dependency>
    <groupId>com.GitHub.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.3.1</version>
</dependency>

导入这个依赖就行了,你可以什么都不配置的。

UserController,原来的查询方法改成这样


@GetMapping("getAllViaMybatis")
public  PageInfo getAllViaMybatis(int page,int rows){
    PageHelper.startPage(page,rows);
    PageInfo pageInfo = new PageInfo(userMapper.getAllUsers());
    return pageInfo;
}

接收page和rows作为分页参数

测试url http://localhost:8888/user/getAllViaMybatis?page=1&rows=10

测试前记得多弄几条数据在数据库

步骤 7 拓展知识:mybatis四种传参方式

通过对象传参


<insert id="insertEmp" parameterType="org.zhang.pojo.Emp">
    insert into emp (ename,job,hiredate,sal) values (#{ename},#{job},#{hiredate},#{sal});
    <selecTKEy resultType="int" keyColumn="empno" keyProperty="empno" order="AFTER">
        select last_insert_id()
    </selectKey>
</insert>

方式1:顺序传参法


<!--    此时因为有多个参数  所以参数类型不能逐一制定 可以省略  有mybatis自动匹配-->
    <update id="updateEmpByNo2">
            update emp set ename=#{param1} where empno=#{param2}
    </update>

方式2:@Param注解传参法
就是在方法的参数列表中置顶要传的参数,然后在sql中直接写


public void updateEmpByNo2(@Param("name") String ename,@Param("no") Integer empno) throws IOException;
<update id="updateEmpByNo2">
        update emp set ename=#{name} where empno=#{no}
</update>

方式3:Map传参法


重点就是 parameterType="HashMap" 这句话

public void updateEmpByNo3(Map<String,Object> argMap) throws IOException;
<update id="updateEmpByNo3" parameterType="hashmap">
        update emp set ename=#{name} where empno=#{no}
</update>

方式4:Java Bean传参法


public User selectUser(Emp emp);
  
 <select id="selectUser" parameterType="org.zhang.pojo.Emp" resultMap="Emp">
     select * from user
     where user_name = #{userName} and dept_id = #{deptId}
 </select>

步骤 8 Mybatis中#{}和${}的区别是什么?

KaTeX parse error: Expected 'EOF', Got '#' at position 10: {}是字符串替换,#̲{}是预处理; Mybatis…{}时,就是把${}直接替换成变量的值。

而Mybatis在处理#{}时,会对sql语句进行预处理,将sql中的#{}替换为?号,调用PreparedStatement的set方法来赋值;

使用#{}可以有效的防止SQL注入,提高系统安全性。

步骤 9 Mybatis中模糊查询like语句该怎么写?

第1种:在Java代码中添加sql通配符,就是把通配符也写在字符串里面带进去。(推荐).


string wildcardname = “%smi%”;
list<name> names = mapper.selectlike(wildcardname);

对应的xml:

select * from foo where bar like #{value}

第2种:在sql语句中拼接通配符,会引起sql注入(不推荐)


string wildcardname = “smi”;
list<name> names = mapper.selectlike(wildcardname);
​
 <span style="color: inherit;">对应的xml:</span>
    <select id=”selectlike”>
         select * from foo where bar like "%"${value}"%"
    </select>

步骤 10 SpringBoot整合Mybatis-plus

MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

在这里插入图片描述

官网文档地址:https://mp.baomidou.com/guide/

首先添加依赖,这一步是必不可少的。


<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.3.1.tmp</version>
</dependency>

步骤 11 Mybatis-plus 如何与 Mybatis 共存?

因为上面的代码都是基于Mybatis的,所以,我们需要让他们共存。办法就是修改application.yml


mybatis-plus:
  mapper-locations: classpath:mybatis/*.xml
  type-aliases-package: com.java18.vipmgr.pojo

把mybayis改成mybatis-plus就可以了,之前的功能一个都不影响!

步骤 12 快速上手Mybatis-plus

因为我们的类名和表明不一致,所以需要做一个配置

User.java


@Data
@TableName("users")
public class User {
    private Integer id;
    private String username;
    private String password;
    private Integer points;
}

UserMapper.java


public interface UserMapper extends BaseMapper<User> {
 //省略之前的代码
}

继承了BaseMapper就可以拥有很多CRUD方法,这一点和JPA很像。

UserController.java


@GetMapping("getAllViaMybatisPlus")
public  IPage<User> getAllViaMybatisPlus(Integer page,Integer rows){
    IPage<User> pageInfo = new Page<>(page, rows);//参数一是当前页,参数二是每页个数
    QueryWrapper<User> wrapper = new QueryWrapper<>();
    pageInfo = userMapper.selectPage(pageInfo,wrapper);
    return pageInfo;
}

测试URL:http://localhost:8888/user/getAllViaMybatisPlus?page=1&rows=10

{“records”:[{“id”:1,“username”:“zhangsan”,“password”:“123”,“points”:1000},{“id”:2,“username”:“lisi”,“password”:“123”,“points”:200},{“id”:3,“username”:“wangwu”,“password”:“123”,“points”:1000},{“id”:4,“username”:“蔡互听”,“password”:“123”,“points”:1000},{“id”:5,“username”:“荀傍支”,“password”:“123”,“points”:1000},{“id”:6,“username”:“养绣洋”,“password”:“123”,“points”:1000},{“id”:7,“username”:“夔惑腔”,“password”:“123”,“points”:1000},{“id”:8,“username”:“戎悦下”,“password”:“123”,“points”:1000},{“id”:9,“username”:“厉触企”,“password”:“123”,“points”:1000},{“id”:10,“username”:“陆糟调”,“password”:“123”,“points”:1000}],“total”:22,“size”:10,“current”:1,“orders”:[],“hitCount”:false,“searchCount”:true,“pages”:3}

以上就是SpringBoot框架整合Mybatis简单攻略的详细内容,更多关于SpringBoot框架整合Mybatis的资料请关注编程网其它相关文章!

--结束END--

本文标题: SpringBoot框架整合Mybatis简单攻略

本文链接: https://lsjlt.com/news/154559.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • SpringBoot框架整合Mybatis简单攻略
    目录步骤 1 添加mybatis-starter依赖步骤 2 如何配置mybatis到SpringBoot项目步骤 3 测试查询步骤 4 mybatis注解方式步骤 5 用注解方式做...
    99+
    2024-04-02
  • springboot框架中如何整合mybatis框架思路详解
    目录springboot框架中如何整合mybatis框架 一、在pom.xml 文件引入对应依赖二、写配置springboot框架中如何整合mybatis框架 思路: 1....
    99+
    2022-12-20
    springboot整合mybatis框架 springboot整合mybatis
  • springboot整合springsecurity与mybatis-plus的简单实现
    1、概述 Spring Security是一个功能强大且高度可定制的身份验证和访问控制框架。 它是用于保护基于Spring的应用程序的实际标准。 Spring Security是一个...
    99+
    2024-04-02
  • SpringBoot整合Mybatis简单实现增删改查
    目录前言第一:创建MySQL数据库第二:创建SpringBoot项目,引入需要的依赖包第三:创建程序目录和配置核心application.xml文件第四:依次编写Entity、Dao...
    99+
    2024-04-02
  • 【企业级框架整合】Springmvc+mybatis+restful+bootstrap框架整合
    1. 使用阿里巴巴Druid连接池(高效、功能强大、可扩展性好的数据库连接池、监控数据库访问性能、支持Common-Logging、Log4j和JdkLog,监控数据库访问)2. 提供高并发JMS消息处理机...
    99+
    2024-04-02
  • SSM(Spring+SpringMVC+Mybatis)框架整合
    1、数据准备 SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- Table structure for `admin` -- ------------------...
    99+
    2014-11-03
    SSM(Spring+SpringMVC+Mybatis)框架整合
  • Spring+SpringMVC+MyBatis+Maven框架整合
    本文记录了Spring+SpringMVC+MyBatis+Maven框架整合的记录,主要记录以下几点 一、Maven需要引入的jar包 二、Spring与SpringMVC的配置分离&...
    99+
    2024-04-02
  • SSM框架整合(Spring+SpringMVC+MyBatis)
    【SSM的系统架构】【整合概述】  MyBatis和Spring整合,通过Spring管理mapper接口。  使用mapper的扫描器自动扫描mapper接口在Spring中进行注册。  通过Spring管理Service接口。  使用配...
    99+
    2023-06-03
  • 若依框架整合mybatis-plus
    在使用若依(RuoYi-vue)时,发现若依用的是mybatis而不是mybatis-plus,所以为了保留原有代码生成器生成的方法,外加入mybaits-plus,故有了下面的内容: ruoyi-admin的prom.xml中添加myba...
    99+
    2023-08-17
    mybatis java mysql
  • SpringBoot整合MyBatis实现增删改查(简单,详细)
    新建springboot工程 若选择https://start.spring.io下一步失败 则选择Custom,输入:https://start.aliyun.com后下一步 添加需要的依赖 添加其他依赖,全部依赖如下: ...
    99+
    2023-08-19
    mybatis spring boot 数据库 mysql
  • SpringBoot框架如何整合SwaggerUI
    这篇文章主要介绍了SpringBoot框架如何整合SwaggerUI的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringBoot框架如何整合SwaggerUI文章都会有所收获,下面我们一起来看看吧。整合s...
    99+
    2023-06-29
  • SpringBoot怎么整合JPA框架
    这篇文章主要介绍了SpringBoot怎么整合JPA框架的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringBoot怎么整合JPA框架文章都会有所收获,下面我们一起来看看吧。一. Spring Boot数...
    99+
    2023-07-04
  • SpringBoot2中怎么整合Mybatis框架
    SpringBoot2中怎么整合Mybatis框架,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一、Mybatis框架1、mybatis简介MyBatis 是一款优秀的持久层框...
    99+
    2023-06-02
  • SpringBoot框架中Mybatis-plus的简单使用操作汇总
    Mybatis-plus 官网地址:https://baomidou.com/ 配置mysql 在配置文件连接mysql spring.datasource.driver-class...
    99+
    2024-04-02
  • Spring+SpringMVC+MyBatis整合实战(SSM框架)
    目录SpringMVCSpringMyBatis项目结构maven配置文件pom.xmlwebapp配置文件web.xmlspring配置文件applicationContext.x...
    99+
    2024-04-02
  • MyBatis-Plus框架整合详细方法
    目录MyBatis-Plus其特性有:引入依赖yml配置主启动类加上包扫码自动生产代码接口util扩展MyBatis-Plus MyBatis-Plus(简称 MP)是一个 MyBa...
    99+
    2024-04-02
  • Java框架入门之简单介绍SpringBoot框架
    前言 Spring都包含了哪些部分呢? 主要包含Spring Boot、Spring Framework、Spring Data、Spring Cloud、Spring Cloud ...
    99+
    2024-04-02
  • springboot整合flowable框架入门步骤
    最近工作中有用到工作流的开发,引入了flowable工作流框架,在此记录一下springboot整合flowable工作流框架的过程,以便后续再次使用到时可以做一些参考使用,如果项目...
    99+
    2024-04-02
  • SpringBoot如何整合Dozer映射框架
    今天小编给大家分享一下SpringBoot如何整合Dozer映射框架的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1. Do...
    99+
    2023-07-02
  • SpringBoot框架整合SwaggerUI的示例代码
    整合swagger进行模块测试 注意事项:为方便SpringBoot更好的整合Swagger,需要专门放置在一个模块中(maven子工程) 创建公共模块,整合swagger,为了所有...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作