黑马 Javaweb - MyBatis 精华篇

我是南城余!阿里云开发者平台专家博士证书获得者!

欢迎关注我的博客!一同成长!

一名从事运维开发的worker,记录分享学习。

专注于AI,运维开发,windows Linux 系统领域的分享!

知识库链接:

MyBatis · 语雀


黑马 Javaweb - MyBatis 精华篇_第1张图片

黑马 Javaweb - MyBatis 精华篇_第2张图片

快速入门

//pojo 实体类层
public class User {
    private Integer id;
    private String name;
    private String username;
    private String gender;
    private Short age;

    public User(Integer id, String name, String username,String gender, Short age) {
        this.id = id;
        this.name = name;
        this.username = username;
        this.gender = gender;
        this.age = age;
    }

    public User() {
    }

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

    public Integer getId() {
        return id;
    }

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

    public String getName() {
        return name;
    }

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

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getGender() {
        return gender;
    }

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

    public Short getAge() {
        return age;
    }

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

//业务逻辑层
@Mapper//在运行时,会自动生成该接口的实现类对象(代理对象),并且将该对象交给IOC容器管理
public interface UserMapper {
    //查询全部用户对象
    @Select("select * from t_user")
    public List  list();

}

//测试层面

@SpringBootTest
class SpringbootMybatisQuickstartApplicationTests {
    @Autowired//将UserMapper 此接口需要在接口前声明@Mapper注解  放入IOC 容器管理的对象创建出来
    private UserMapper userMapper;

    @Test
    void textListUser() {
        List list = userMapper.list();
        list.stream().forEach(user ->  System.out.println(user));
    }

}

配置SQL提示

黑马 Javaweb - MyBatis 精华篇_第3张图片

黑马 Javaweb - MyBatis 精华篇_第4张图片

JDBC

黑马 Javaweb - MyBatis 精华篇_第5张图片

数据库连接池

黑马 Javaweb - MyBatis 精华篇_第6张图片

黑马 Javaweb - MyBatis 精华篇_第7张图片

黑马 Javaweb - MyBatis 精华篇_第8张图片

黑马 Javaweb - MyBatis 精华篇_第9张图片

lombok

黑马 Javaweb - MyBatis 精华篇_第10张图片

进阶

黑马 Javaweb - MyBatis 精华篇_第11张图片

MyBatis crud

这些方法主要在mapper中写crud方法,并且加上对应的注解

1. 删除

黑马 Javaweb - MyBatis 精华篇_第12张图片

mybatis日志输出在yaml配置文件中配置日志开启,具体可见下面截图

黑马 Javaweb - MyBatis 精华篇_第13张图片

黑马 Javaweb - MyBatis 精华篇_第14张图片

SQL注入,参数占位符

解决上去了注入,生成预编译SQL

#{}:参数传递

${}:表名、列名进行动态设置

两者{}中放置的都是实体类中的属性

黑马 Javaweb - MyBatis 精华篇_第15张图片

黑马 Javaweb - MyBatis 精华篇_第16张图片

2. 插入(insert)

黑马 Javaweb - MyBatis 精华篇_第17张图片

主键返回 需要在方法上增添Options注解,并标明属性值

黑马 Javaweb - MyBatis 精华篇_第18张图片

黑马 Javaweb - MyBatis 精华篇_第19张图片

3. 更新(update)

黑马 Javaweb - MyBatis 精华篇_第20张图片

4. 查询(select)

解决查询出来为null的方法

  1. 在方法查询SQL中起别名,使SQL中的字段映射与实体类属性值映射
  2. 在方法中添加@Results和@Result 注解
  3. 在yaml中配置驼峰命名法 (在方法中继续使用原SQL即可)

黑马 Javaweb - MyBatis 精华篇_第21张图片

条件查询

解决模糊查询的SQL注入问题

  1. 接口方法,使用${name}
  2. 使用原SQL语句中的concat(字符串拼接),直接在SQL语句中进行解决。

黑马 Javaweb - MyBatis 精华篇_第22张图片

黑马 Javaweb - MyBatis 精华篇_第23张图片

5. xml配置文件(映射)

在mybatis中有两种方法进行mapper方法中的SQL书写,一种是直接在方法中书写,另外一种则是xml文件映射

黑马 Javaweb - MyBatis 精华篇_第24张图片

黑马 Javaweb - MyBatis 精华篇_第25张图片

黑马 Javaweb - MyBatis 精华篇_第26张图片

6. 动态SQL
6.1. if标签

用if标签来指定查询,也就是动态SQL

引入where动态判断是否需要where后面的查询语句

黑马 Javaweb - MyBatis 精华篇_第27张图片

引入set标签,解决 update标签后面的set问题

黑马 Javaweb - MyBatis 精华篇_第28张图片

黑马 Javaweb - MyBatis 精华篇_第29张图片

6.2. foreach标签

常用于批量操作中,例如,删除delete in 或者select in

黑马 Javaweb - MyBatis 精华篇_第30张图片

6.3. sql include标签

黑马 Javaweb - MyBatis 精华篇_第31张图片

黑马 Javaweb - MyBatis 精华篇_第32张图片

你可能感兴趣的:(南城余的Java学习,mybatis)