博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【Java】Mybatis mapper动态代理方式
阅读量:6720 次
发布时间:2019-06-25

本文共 2608 字,大约阅读时间需要 8 分钟。

前言

我们在使用Mybatis的时候,获取需要执行的SQL语句的时候,都是通过调用xml文件来获取,例如:User user = (User) sqlSession.selectOne("cn.ddnd.www.Entity.User.getUser", "xue8@qq.com");。这种方式是通过字符串去调用标签定义的SQL语句,第一容易出错,第二是当xml当中的id修改过后你不知道在程序当中有多少个地方使用了这个id,需要手动一一修改。后来Mybatis推出了Mapper动态代理方式,只需要编写Mapper接口(相当于Dao层),由Mybatis框架根据接口定义创建接口的动态代理对象。

Mapper接口规范

  1. Mapper.xml中的namespace和Mapper.java接口中的类路径相同,即<mapper namespace="cn.ddnd.www.Dao.User">对应的是cn.ddnd.www.Dao包下的User类。
  2. Mapper.xml中的selectID要和Mapper.java接口中的类方法名相同,即<select id="getUser" parameterType="String" resultType="User">getUserpublic User getUser(String email);getUser方法名对应。
  3. Mapper.xml中的parameterType的类型要和Mapper接口中方法的传入参数类型相同。
  4. Mapper.xml中的resultType的类型要和Mapper接口中方法的返回参数类型相同。

实现过程

配置Mapper.xml

IUser.xml:

复制代码

配置Mapper.java接口

IUser.java:

package cn.ddnd.www.Dao;import cn.ddnd.www.Entity.User;public interface IUser {    public User getUser(String email);}复制代码

编写Mybatis配置文件

Mybatis-config.xml:

复制代码

测试类

test.java:

import cn.ddnd.www.Dao.IUser;import cn.ddnd.www.Entity.User;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import org.junit.Test;import org.apache.ibatis.io.Resources;import java.io.Reader;import java.io.IOException;public class test {    private static Reader reader;    private static SqlSessionFactory sqlSessionFactory;    static{        try{            reader = Resources.getResourceAsReader("Mybatis-config.xml");            sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);        }catch (IOException e){            e.printStackTrace();        }    }    @Test    public void a() throws IOException {        SqlSession sqlSession = sqlSessionFactory.openSession();        try{            IUser IUser = (IUser) sqlSession.getMapper(IUser.class);            User user = IUser.getUser("xue8@qq.com");            System.out.println("用户的邮箱是:" + user.getEmail() + ",用户的名称是:" + user.getName() + ",用户的密码是:" + user.getPassword());        }finally {            sqlSession.close();        }    }}复制代码

IUser IUser = (IUser) sqlSession.getMapper(IUser.class);sqlSession会帮我们生成一个实现类(给IUser接口),这样即可获取IUser接口的代理对象。User user = IUser.getUser("xue8@qq.com");代理对象方法。

转自:

转载于:https://juejin.im/post/5c0155096fb9a049d235c8e5

你可能感兴趣的文章
Ubuntu下彻底删除vim
查看>>
HTML页面静态化实现
查看>>
关于selenium中断言判断url获取错误解决
查看>>
mysql的排障之二
查看>>
oracle 恢复学习 案例1 一个数据文件丢失 完全恢复数据库
查看>>
OpenStack 搭建(三)
查看>>
sendmail在企业网中的应用(下)
查看>>
zabbix日志监控
查看>>
竖直滚动 jquery 文字 图片
查看>>
设计模式系列-装饰模式
查看>>
C# Lambda表达式Contains方法&#160;like
查看>>
第三章--进程
查看>>
Docker部署CouchDB
查看>>
关于namespace的一点点心得体会(2017年8月3日14:55:37)
查看>>
Android Studio中默认图标的引用
查看>>
keepalived的原理和基本实现
查看>>
Android Activity之间动画完整版详解
查看>>
绕过管理员验证登陆!
查看>>
Android Studio 初体验
查看>>
MySQL常用DDL、DML、DCL语言整理(附样例)
查看>>