【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中的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:

<?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 configurationPUBLIC "-//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();}}@Testpublic 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/…

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/450118.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

git pull时冲突的几种解决方式

仅结合本人使用场景&#xff0c;方法可能不是最优的 1. 忽略本地修改&#xff0c;强制拉取远程到本地 主要是项目中的文档目录&#xff0c;看的时候可能多了些标注&#xff0c;现在远程文档更新&#xff0c;本地的版本已无用&#xff0c;可以强拉 git fetch --allgit reset --h…

Android应用开发—eventBus发布事件和事件处理的时序关系

占坑&#xff0c;简单说明下eventBus发布事件和事件处理的时序关系。 什么时候使用sticky&#xff1a; 当你希望你的事件不被马上处理的时候&#xff0c;举个栗子&#xff0c;比如说&#xff0c;在一个详情页点赞之后&#xff0c;产生一个VoteEvent&#xff0c;VoteEvent并不立…

grep命令 解说

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 grep&#xff08;global search regular expression(RE) and print out the line&#xff0c;全面搜索正则表达式并把行打印出来&#x…

创业第一桶金怎么来

文章摘要&#xff1a;资金是创业要具备的一个必要条件&#xff0c;那么对于创业者来说&#xff0c;第一桶金如何取得&#xff1f;资金是创业要具备的一个必要条件&#xff0c;那么对于创业者来说&#xff0c;第一桶金如何取得&#xff1f;   一、一门手艺   都说拥有万贯…

4001.基于双向链表的双向冒泡排序法

基于双向链表的双向冒泡排序法 发布时间: 2018年11月26日 10:09 时间限制: 1000ms 内存限制: 128M 习题集源码中出现了 temp->next->prior p; 本人推断这里缺少预先的对temp->nextNULL这种情况的判定&#xff0c;所以需加入一个判断语句解决。 此为非循环的双向链…

页面向上滚动

#页面或者div向上无缝滚动 1.css: body {margin: 0;padding: 0;overflow: hidden;}.container {position: relative;top: 0;}.container div {width: 500px;height: 500px;border: 1px solid chartreuse;font-size: 100px;line-height: 500px;font-weight: bold;color: black;t…

叨逼叨

此处记录点零散的小idea&#xff0c;为了避免把csdn当微博&#xff0c;开一篇&#xff0c;都记在这里吧。 感觉服务注册机制&#xff0c;貌似也是一种依赖注入。&#xff08;虽然我还没完全搞懂依赖注入&#xff09;&#xff0c;理由呢&#xff1a;你需要一个模块的功能&#x…

Linux:echo命令详解

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 echo命令 用于字符串的输出 格式 echo string使用echo实现更复杂的输出格式控制 1.显示普通字符串: echo "It is a test"这里…

看年轻人如何赚第一桶金

上世纪90年代&#xff0c;成为百万富翁&#xff0c;对很多人只是个梦想。不过如今&#xff0c;随着经济飞速发展&#xff0c;拥有百万资产已经不再是神话&#xff0c;放眼望去&#xff0c;我们身边的百万富翁比比皆是&#xff0c;甚至很多初入社会、白手起家的年轻人&#xff0…

跨越解决方案之nginx

这里是修真院前端小课堂&#xff0c;每篇分享文从 【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】 八个方面深度解析前端知识/技能&#xff0c;本篇分享的是&#xff1a; 【跨越解决方案之nginx】 1.背景介绍 跨域&#x…

学习 shell脚本之前的基础知识

见 : http://www.92csz.com/study/linux/12.htm【什么是shell】 简单点理解&#xff0c;就是系统跟计算机硬件交互时使用的中间介质&#xff0c;它只是系统的一个工具。实际上&#xff0c;在shell和计算机硬件之间还有一层东西那就是系统内核了。打个比方&#xff0c;如果把计算…

「分块系列」数列分块入门3 解题报告

数列分块入门3 题意概括 区间加法&#xff0c;区间求前驱。 写在前面 这题的方法与分块2方法极其类似&#xff0c;建议自行解决。 正题 和上一题类似&#xff0c;但是二分不是用来计数的&#xff0c;而是用来求小于c的最大值的。然后对于不完整快&#xff0c;将小于c的值求最大…

创业者自述:我的第一桶金是如何来的

记者采访王宏筠的当天&#xff0c;北京气温已达到30℃&#xff0c;王宏筠从他的铁灰色奥迪A6车上下来&#xff0c;一身挺括的西装&#xff0c;打着领带&#xff0c;肩上背着一个超大的牛皮包。后来他对记者说&#xff0c;穿西服是因为多年在外企养成的习惯&#xff0c;一年中至…

Git cherry-pick后再merge出现一个“奇怪”的现象

背景描述&#xff1a;有的时候基于一个master branch拉出一个独立feature分支做开发时&#xff0c;两条分支都在并行开发&#xff0c;如果master分支增加了某些功能&#xff0c;解决了某些关键bug&#xff0c;而独立feature分支不需要所有的增加的commit&#xff0c;只需要某一…

inux系统中如何进入退出vim编辑器

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 VIM编辑器&#xff0c;可以新建文件也可以修改文件&#xff0c;命令为&#xff1a;vim AAA 。AAA就是文件名。 如果这个文件&#xff…

C++ 智能指针六

/* 智能指针unique_ptr */#include <iostream> #include <string> #include <memory> #include <vector>/*unique_ptr 独占所指向的对象, 同一时刻只能有一个 unique_ptr 指向给定对象(通过禁止拷贝语义, 只有移动语义来实现), 定义于 memory (非memo…

如何掘到第一桶金

第一种类型&#xff1a;才智高远型 典型代表&#xff1a;《福布斯》中国富豪榜排名第一位、个人资产总计达到83亿元的中国希望集团刘氏兄弟。 与一般的创业者不同&#xff0c;刘氏四兄弟刘永言、刘永行、刘永美、刘永好一开始就悟透了“舍得”二字。他们本来都在国家企事业单…

Sublime Text3中文环境设置

Sublime Text3中文环境设置 1、首先打开安装好的的Sublime软件,选择Preferences下面的Package Contorol选项出现弹窗方框 2、在弹窗输入install package,选择对应&#xff08;默认第一个&#xff0c;如图这个&#xff09;命令点击进入;安装的时候&#xff0c;左下角会有进度条显…

C/C++图形化编程(2)

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 站在巨人的肩上是为了超过巨人&#x…

Git clone之后你的硬盘上究竟发生了什么?

网上关于Git的使用有太多的博客&#xff0c;文章在讲解了&#xff0c;大部分是在讲解命令的用法&#xff0c;剩下一部分则在讲解git的内部原理&#xff0c;看过讲解基础命令使用的文章后&#xff0c;正常的开发使用是没有什么问题的了&#xff0c;而如果想更深入的了解git“高级…