MyBatis的使用

本文介绍了如何在SpringBoot项目中集成并使用MyBatis,包括引入依赖、创建POJO类、配置Mapper文件、使用@MapperScan注解、编写Mapper接口和XML文件,以及测试查询和插入操作。通过这个教程,读者可以快速掌握SpringBoot结合MyBatis的基本应用。
摘要由CSDN通过智能技术生成

springboot中使用MyBatis

好久没有用MyBatis,趁回顾的时间总结下MyBatis使用的步骤。

第一步:引入依赖

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

第二步:写出POJO类

根据数据库中的数据类型与数据名称编写相对应的类(必须具有get与set方法)

举个例子:

@Data
public class AdminUser {
    private Integer user_id;
    private String user_name;
    private String user_password;
    private String nikename;
    private Byte locked;
}

第三步:配置Mapper的XML文件

在application.properties中配置mapper文件的位置(必配)

# mybatis config
mybatis.mapper-locations=classpath:mapper/*Mapper.xml

maven构建web项目的时候,resource目录就是默认的classpath

*/mapper是使用通配符的格式:表示结尾是Mappper的xml文件

第四步:Mapper的组件查询注释

两种方式,即两种注释

@Mapper或者**@Mappersccan**(推荐)

1、@Mapper注解:
作用:在接口类上添加了@Mapper,在编译之后会生成相应的接口实现类
添加位置:接口类上面

@Mapper
public interface UserDAO {
    //代码

如果想要每个接口都要变成实现类,那么需要在每个接口类上加上@Mapper注解,比较麻烦,解决这个问题用@MapperScan

2、@MapperScan
作用:指定要变成实现类的接口所在的包,然后包下面的所有接口在编译之后都会生成相应的实现类
添加位置:是在Springboot启动类上面添加,

@SpringBootApplication
@MapperScan("com.winter.dao")
public class SpringbootMybatisDemoApplication {

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

添加@MapperScan(“com.winter.dao”)注解以后,com.winter.dao包下面的接口类,在编译之后都会生成相应的实现类.

第五步:编写接口

编写我们使用数据库层的接口,此接口将与xml一一对应

public interface AdminUserMapper {
    AdminUser loginuser(String username,String password);
}

第六步:编写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">
//表示该XML文件的环境与适用环境
<mapper namespace="com.site.blog.my.core.dao.AdminUserMapper">
//表示所对应接口的地址
    <resultMap id="BaseResultMap" type="com.site.blog.my.core.entity.AdminUser">
        <id column="admin_user_id"  property="user_id" />
        <result column="login_user_name"  property="user_name" />
        <result column="login_password"  property="user_password" />
        <result column="nick_name" property="nikename" />
        <result column="locked"  property="locked" />
    </resultMap>
//表示该XML与接口所对应的POJO类
    <select id="loginuser" resultMap="BaseResultMap" parameterType="string">
        select * from tb_admin_user where login_user_name=#{username} and login_password=#{password}
    </select>
    <insert id="insertwhatdo" parameterType="com.site.blog.my.core.entity.AdminUser">
        insert into tb_admin_user(admin_user_id,login_user_name,login_password,nick_name,locked)
        value (#{user_id},#{user_name},#{user_password},#{nikename},#{locked})
    </insert>
</mapper>

使用(测试)

@RestController
public class test {
    @Resource
    AdminUserMapper adminUserMapper;

    @GetMapping("/test1")
    public void test1(){
        AdminUser adminUser=new AdminUser();
        adminUser.setUser_id(123);
        adminUser.setUser_name("wangyaze");
        adminUser.setNikename("321");
        adminUser.setUser_password("wwwwww");
        adminUser.setLocked((byte) 0);
        adminUserMapper.insertwhatdo(adminUser);
    }
    @GetMapping("/test2")
    public String test2(){
        AdminUser adminUser=new AdminUser();
        adminUser=adminUserMapper.loginuser("wangyaze","wwwwww");
        String lastnick=adminUser.getNikename();
        return lastnick;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值