菜鸟之路Day33一一Mybatis入门

简介: 本文是《菜鸟之路Day33——Mybatis入门》的教程,作者blue于2025年5月18日撰写。文章介绍了MyBatis作为一款优秀的持久层框架,如何简化JDBC开发。通过创建SpringBoot工程、数据库表`user`及实体类`User`,引入MyBatis依赖并配置数据库连接信息,使用注解方式编写SQL语句实现查询所有用户数据的功能。此外,还展示了如何通过Lombok优化实体类代码,减少冗余的getter/setter等方法,提高开发效率。最后通过单元测试验证功能的正确性。

菜鸟之路Day33一一Mybatis入门

作者:blue

时间:2025.5.18

文章内容学习自黑马程序员BV1m84y1w7Tb

MyBatis是一款优秀的持久层框架,用于简化JDBC的开发

入门案例:使用Mybatis查询所有用户数据

1.准备工作(创建springboot工程,数据库表user,实体类User)

创建springboot工程

image-20250518204351561.png

创建User表

image-20250525204409931.png

并在其中任意添加若干条数据项

创建实体类User

package com.bluening.mybatis_demo.pojo;

public class User {
   
    private int id;
    private String name;
    private int age;
    private int gender;
    private String phone;

    public User() {
   
    }

    public User(int id, String name, int age, int gender, String phone) {
   
        this.id = id;
        this.name = name;
        this.age = age;
        this.gender = gender;
        this.phone = phone;
    }

    public int getId() {
   
        return id;
    }

    public void setId(int id) {
   
        this.id = id;
    }

    public String getName() {
   
        return name;
    }

    public void setName(String name) {
   
        this.name = name;
    }

    public int getAge() {
   
        return age;
    }

    public void setAge(int age) {
   
        this.age = age;
    }

    public int getGender() {
   
        return gender;
    }

    public void setGender(int gender) {
   
        this.gender = gender;
    }

    public String getPhone() {
   
        return phone;
    }

    public void setPhone(String phone) {
   
        this.phone = phone;
    }

    @Override
    public String toString() {
   
        return "User{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                ", gender=" + gender +
                ", phone='" + phone + '\'' +
                '}';
    }
}

2.引入Mybatis的相关依赖,配置Mybatis(数据库连接信息)

在application.properties配置文件中配置数据库连接信息

spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306
spring.datasource.username=root
spring.datasource.password=1234

3.编写SQL语句(注解/XML)

package com.bluening.mybatis_demo.mapper;

import com.bluening.mybatis_demo.pojo.User;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.util.List;

@Mapper //在运行时,会自动生成该接口的实现类对象(代理对象),并将该对象交给IOC容器管理
public interface UserMapper {
   
    //查询用户全部信息
    @Select("select * from user")
    public List<User> findAll();
}
  • @Mapper@Select 是 MyBatis 的注解,用于声明映射器和 SQL 查询。
  • @Mapper 注解
    • 告诉 MyBatis 这是一个映射器接口。
    • 运行时 MyBatis 会自动生成该接口的代理实现类,并注册到 Spring 的 IOC 容器中。
  • @Select 注解
    • 直接在接口方法上声明 SQL 查询语句。
    • 等效于在 XML 配置文件中编写 <select> 标签。
  • 方法签名
    • 返回类型 List<User> 表示查询结果将映射为 User 对象列表。
    • 方法名 findAll() 是自定义的,用于描述查询功能。
  • 执行流程
    1. 调用 userMapper.findAll() 时,MyBatis 执行 SQL:SELECT * FROM user
    2. 将结果集自动映射到 User 对象列表。

单元测试

package com.bluening.mybatis_demo;

import com.bluening.mybatis_demo.mapper.UserMapper;
import com.bluening.mybatis_demo.pojo.User;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.util.List;

@SpringBootTest//springboot整合单元测试的注解
class MybatisDemoApplicationTests {
   

    @Autowired
    private UserMapper userMapper;

    @Test
    public void testListUser() {
   
        List<User> users = userMapper.findAll();
        for (User user : users) {
   
            System.out.println(user);
        }
    }

}

4.lombok

以上代码存在实体类过于臃肿的问题,这时我们可以使用lombok来优化

Lombok是一个实用的java类库,能通过注解的形式自动生成构造器,getter/setter,equals,hashcode,toString等方法,并可以自动化生成日志变量,简化java开发,提高效率

注解 作用
@Getter/Setter 为所有的属性提供get/set方法
@ToString 会给类自动生成易阅读的toString方法
@EqualsAndHashCode 根据类所拥有的非静态字段自动重写equals方法和hashCode方法
@Data 提供了更综合生成代码的功能(@Getter+@Setter+@ToString+@EqualsHashCode)
@NoArgsConstructor 为实体类生成无参的构造器方法
@AllArgsConstructor 为实体类生成除了static修饰的字段之外带有各参数的构造器方法

引入依赖

 <!--lombok-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>

修改实体类

import lombok.Data;

@Data
@NoArgsConstructor
@AllArgsConstructor
public class User {
   
    private int id;
    private String name;
    private int age;
    private int gender;
    private String phone;
}
目录
相关文章
|
SQL Java 数据库连接
MyBatis 框架入门理论与实践
MyBatis 框架入门理论与实践
128 6
|
6月前
|
SQL 缓存 Java
【吐血整理】MyBatis从入门到精通
本文介绍了 MyBatis 的使用指南,涵盖开发环境搭建、基础操作实例和进阶特性。首先,详细描述了 JDK 和 IDE 的安装及依赖引入,确保项目顺利运行。接着,通过创建用户表和实体类,演示了 CRUD 操作的全流程,包括查询、插入、更新和删除。最后,深入探讨了动态 SQL 和缓存机制等高级功能,帮助开发者提升数据库交互效率和代码灵活性。掌握这些内容,能显著提高 Java 编程中的数据库操作能力。
992 4
|
4月前
|
Java 关系型数据库 数据库连接
Javaweb之Mybatis入门程序的详细解析
本文详细介绍了一个MyBatis入门程序的创建过程,从环境准备、Maven项目创建、MyBatis配置、实体类和Mapper接口的定义,到工具类和测试类的编写。通过这个示例,读者可以了解MyBatis的基本使用方法,并在实际项目中应用这些知识。
125 11
|
XML Java 数据库连接
MyBatis入门——MyBatis XML配置文件(3)
MyBatis入门——MyBatis XML配置文件(3)
450 6
|
Java 关系型数据库 数据库连接
MyBatis入门(1)
MyBatis入门(1)
113 2
|
9月前
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
1966 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
|
Java 数据库连接 测试技术
MyBatis-Plus入门
MyBatis-Plus入门
115 0
|
9月前
|
SQL Java 数据库连接
Mybatis入门(select标签)
这篇文章介绍了Mybatis中`select`标签的基本用法及其相关属性,并通过示例展示了如何配置和执行SQL查询语句。
164 0
Mybatis入门(select标签)
|
11月前
|
Java 数据库连接 Spring
后端框架入门超详细 三部曲 Spring 、SpringMVC、Mybatis、SSM框架整合案例 【爆肝整理五万字】
文章是关于Spring、SpringMVC、Mybatis三个后端框架的超详细入门教程,包括基础知识讲解、代码案例及SSM框架整合的实战应用,旨在帮助读者全面理解并掌握这些框架的使用。
后端框架入门超详细 三部曲 Spring 、SpringMVC、Mybatis、SSM框架整合案例 【爆肝整理五万字】
|
11月前
|
SQL Java 数据库连接
Spring Boot联手MyBatis,打造开发利器:从入门到精通,实战教程带你飞越编程高峰!
【8月更文挑战第29天】Spring Boot与MyBatis分别是Java快速开发和持久层框架的优秀代表。本文通过整合Spring Boot与MyBatis,展示了如何在项目中添加相关依赖、配置数据源及MyBatis,并通过实战示例介绍了实体类、Mapper接口及Controller的创建过程。通过本文,你将学会如何利用这两款工具提高开发效率,实现数据的增删查改等复杂操作,为实际项目开发提供有力支持。
778 0