Mybatis - Mapper代理开发目的与入门案例

文章目录

  • Mapper代理开发
    • 目的
  • Mapper代理方式入门案例
    • 1.完成Mapper文件映射
      • 创建包
      • 创建并放入模拟接口
      • 创建目录
      • 编译
      • 映射文件成功
    • 2.设置映射文件的namespace属性
    • 3.在Mapper接口中定义方法
      • 更改mybatis-config.xml
    • 4.模拟代理开发
      • demo02源码
      • 异常
      • 再次编译运行
      • complete!!

Mapper代理开发

目的

  • 解决原生方式中的硬编码
  • 简化后期执行SQL

Mapper代理方式入门案例

  1. 定义与SQL映射文件同名的Mapper接口,并且将Mapper接口和SQL映射文件放置在同一目录下

  2. 设置SQL映射文件的namespace属性为Mapper接口全限定名

  3. 在Mapper接口中定义方法,方法名就是SQL映射文件中sql语句的id,并保持参数类型和返回值类型一致

  4. 编码

1.完成Mapper文件映射

定义与SQL映射文件同名的Mapper接口,并且将Mapper接口和SQL映射文件放置在同一目录下

创建包

Mybatis - Mapper代理开发目的与入门案例_第1张图片

创建并放入模拟接口

Mybatis - Mapper代理开发目的与入门案例_第2张图片

创建目录

让Mapper接口与xml文件在同一目录下

  1. 我们可以直接用鼠标拖动,但是显然不合适,文件比较乱,不方便管理
  2. 我们在resources里新建目录,并映射

注意格式(要与mapper文件路径一致)

Mybatis - Mapper代理开发目的与入门案例_第3张图片

编译

把Tb_userMapper.xml文件移动到该目录下,并进行编译,这里我们使用maven插件进行编译

Mybatis - Mapper代理开发目的与入门案例_第4张图片

Mybatis - Mapper代理开发目的与入门案例_第5张图片

映射文件成功

Mybatis - Mapper代理开发目的与入门案例_第6张图片

2.设置映射文件的namespace属性

设置SQL映射文件的namespace属性为Mapper接口全限定名

Mybatis - Mapper代理开发目的与入门案例_第7张图片

3.在Mapper接口中定义方法

在Mapper接口中定义方法,方法名就是SQL映射文件中sql语句的id,并保持参数类型和返回值类型一致

Mybatis - Mapper代理开发目的与入门案例_第8张图片

更改mybatis-config.xml

右键 - copy-path

Mybatis - Mapper代理开发目的与入门案例_第9张图片

Mybatis - Mapper代理开发目的与入门案例_第10张图片

4.模拟代理开发

复制demo02

Mybatis - Mapper代理开发目的与入门案例_第11张图片

demo02源码

package com.taotao;

import com.taotao.mapper.UserMapper;
import com.taotao.pojo.Tb_user;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;

/**
 * Create By 刘鸿涛
 * 2022/3/12 20:27
 * Mybatis 代理开发
 */
public class MyBatisDemo02 {
    public static void main(String[] args) throws IOException {
        //1.加载mybatis的核心配置文件,获取 SqlSessionFactory
        String resource = "mybatis-config.xml"; //相对路径
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);


        //2.获取SqlSession对象,用它来执行sql
        SqlSession sqlSession = sqlSessionFactory.openSession();

        //3.执行sql
//        List users = sqlSession.selectList("test.selectAll");
        //3.1 获取userMapper接口的代理对象
        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
        List<Tb_user> tb_users = userMapper.selectAll();
        System.out.println(tb_users);

        //4.释放资源
        sqlSession.close();
    }
}

异常

Mybatis - Mapper代理开发目的与入门案例_第12张图片

我换了root密码,所以重新改下root’@'localhost密码即可

Mybatis - Mapper代理开发目的与入门案例_第13张图片

再次编译运行

Mybatis - Mapper代理开发目的与入门案例_第14张图片

complete!!

Mybatis - Mapper代理开发目的与入门案例_第15张图片

你可能感兴趣的:(成长阶段,笔记,Java开发必备,java,代理模式,开发语言)