【Java】Mybatis mapper动态代理方式

栏目: Java · 发布时间: 7年前

内容简介:我们在使用Mybatis的时候,获取需要执行的SQL语句的时候,都是通过调用xml文件来获取,例如:IUser.xml:IUser.java:
【Java】Mybatis mapper动态代理方式

我们在使用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中的 select ID要和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:

<?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">

<mapper namespace="cn.ddnd.www.Dao.IUser">
    <select id="getUser" parameterType="String" resultType="User">
        select * from user where email = #{email}
    </select>
</mapper>
复制代码

配置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:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">

<configuration>
    <typeAliases>
        <typeAlias type="cn.ddnd.www.Entity.User" alias="User"></typeAlias>
    </typeAliases>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://127.0.0.1:3306/spring?serverTimezone=GMT%2B8" />
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="cn/ddnd/www/Dao/IUser.xml"></mapper>
    </mappers>
</configuration>
复制代码

测试类

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"); 代理对象方法。

转自:ddnd.cn/2018/11/30/…


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

高效前端:Web高效编程与优化实践

高效前端:Web高效编程与优化实践

李银城 著 / 机械工业出版社 / 2018-3-15 / 89.00元

这不是一本单纯讲解前端编程技巧的书,而是一本注重思想提升和内功修炼的书。 全书以问题为导向,精选了前端开发中的34个疑难问题,从分析问题的原因入手,逐步给出解决方案,并分析各种方案的优劣,最后针对每个问题总结出高效编程的最佳实践和各种性能优化的方法。 全书共7章,内容从逻辑上大致可以分为两大类: 第一类,偏向实践,围绕HTML、CSS、JavaScript等传统前端技术,以及PW......一起来看看 《高效前端:Web高效编程与优化实践》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试