使用Mybatis开发Dao,通常有两个方法,即原始Dao开发方法和Mapper接口开发方法。 Mapper接口开发方式是基于入门程序的基础上,对 控制程序 进行分层开发,程序员只需要 编写mapper接口Mappe.xml 配置文件即可,程序员编写mapper接口需要遵循一些开发规范,mybatis可以自动生成mapper接口实现类代理对象。

一、SQL配置文件

1、EmpMapper.xml

使用Mapper动态代理的方式开发时, 映射文件namespace 必须为  Mapper接口文件全名

 <?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="Mapper.EmpMapper">
<!-- 根据id获取员工信息 -->
<select id="findEmpById" parameterType="int" resultType="po.Emp">
select * from emp where empno = #{empno}
</select> <!-- 自定义条件查询员工列表 -->
<select id="findEmpByEmpname" parameterType="java.lang.String" resultType="po.Emp">
select * from emp where ename like '%${value}%'
</select> <!-- 添加员工信息 -->
<insert id="insertEmp" parameterType="po.Emp">
<selectKey keyProperty="empno" order="AFTER" resultType="java.lang.Integer">
select LAST_INSERT_ID()
</selectKey>
insert into emp(ename,job) values(#{ename},#{job})
</insert> <!-- 删除员工信息 -->
<delete id="deleteEmpById" parameterType="int">
delete from emp where empno=#{empno}
</delete> <!-- 更新员工信息 -->
<update id="updateEmp" parameterType="po.Emp">
update emp set ename=#{ename},job=#{job}
where empno=#{empno}
</update>
</mapper>

2、pojo类

 package po;
//导入相关类
public class Emp {
private int empno;
private String ename;
private String job;
private int mgr;
private Date hiredate;
private double sal;
private double comm;
private int deptno; @Override
public String toString() {
return "编号:"+empno+" 姓名:"+ename+" 工作:"+job+"\n";
}
set()/get()方法 ...
}

3、SqlMapConfig.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>
<!-- 和spring整合后 environments配置将废除-->
<environments default="development">
<environment id="development">
<!-- 使用jdbc事务管理-->
<transactionManager type="JDBC" />
<!-- 数据库连接池-->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/
scott?characterEncoding=utf-8" />
<property name="username" value="root" />
<property name="password" value="su486213" />
</dataSource>
</environment>
</environments> <!-- 加载映射文件 -->
<mappers>
<mapper resource="Mapper/EmpMapper.xml"/>
</mappers>
</configuration>

二、Dao层

1、开发规范

程序员编写mapper接口需要遵循一些开发规范,mybatis可以自动生成mapper接口实现类代理对象。相关的开发规范如下:

① 在mapper.xml中namespace等于mapper接口地址

② 接口中的方法名和mapper.xml中statement的id一致

③ 接口中的方法输入参数类型和mapper.xml中statement的parameterType指定的类型一致

④ 接口中的方法返回值类型和mapper.xml中statement的resultType指定的类型一致

总结:以上开发规范主要是对下边的代码进行统一生成:

 //在方法体内通过SqlSessionFactory创建SqlSession
SqlSession sqlSession = sqlSessionFactory.openSession();
//业务操作语句
Emp emp = sqlSession.selectOne("test.findEmpById",empno);

2、Mapper接口

 package Mapper;
//导入相关类
public interface EmpMapper {
public Emp findEmpById(int empno);
public List<Emp> findEmpByEmpname(String tname);
public int insertEmp(Emp emp);
public int deleteEmpById(int empno);
public int updateEmp(Emp emp);
}

三、测试程序

1、Junit单元测试

 package Test;
//导入相关类
public class Mybatis_Mapper { //使用 单例模式 管理会话工厂
private SqlSessionFactory sqlSessionFactory;
@Before
public void createSqlSessionFactory() throws IOException {
// Mybatis配置文件
String resource = "SqlMapConfig.xml";
// 得到配置文件流
InputStream inputStream = Resources.getResourceAsStream(resource);
// 创建会化工厂,传入Mybatis配置文件信息
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} // 根据 id查询部门信息
@Test
public void testFindEmpById() {
SqlSession sqlSession = sqlSessionFactory.openSession();
//创建EmpMapper对象,mybatis自动生成mapper代理对象
EmpMapper empMapper = sqlSession.getMapper(EmpMapper.class);
Emp emp = null; try {
//调用empMapper的方法
emp = empMapper.findEmpById(7900);
}finally {
sqlSession.close();
} System.out.println(emp);
} // 根据员工姓名模糊查询员工信息
@Test
public void testFindEmpByEmpname() {
SqlSession sqlSession = sqlSessionFactory.openSession();
EmpMapper empMapper = sqlSession.getMapper(EmpMapper.class);
List<Emp> emp = null; try {
//调用empMapper的方法
emp = empMapper.findEmpByEmpname("th");
}
finally {
sqlSession.close();
} for(Emp e:emp) {
System.out.println(e);
}
} // 添加员工信息
@Test
public void testInsert() {
SqlSession sqlSession = sqlSessionFactory.openSession();
EmpMapper empMapper = sqlSession.getMapper(EmpMapper.class);
Emp emp = new Emp();
emp.setEname("admin");
emp.setJob("admin"); int flag = 0;
try {
flag = empMapper.insertEmp(emp);
}finally {
sqlSession.commit();
sqlSession.close();
} if(flag == 1) {
System.out.println("自增主键值:"+emp.getEmpno());
}
} // 更新员工信息
@Test
public void testUpdate() {
SqlSession sqlSession = sqlSessionFactory.openSession();
EmpMapper empMapper = sqlSession.getMapper(EmpMapper.class);
Emp emp = new Emp();
emp.setEmpno(7950);
emp.setEname("test7950");
emp.setJob("test7950"); int flag = 0;
try {
flag = empMapper.updateEmp(emp);
}finally {
sqlSession.commit();
sqlSession.close();
} if(flag == 1) {
System.out.println("更新成功!");
}
} // 根据id删除员工信息
@Test
public void testDelete() {
SqlSession sqlSession = sqlSessionFactory.openSession();
EmpMapper empMapper = sqlSession.getMapper(EmpMapper.class); int flag = 0;
try {
flag = empMapper.deleteEmpById(7950);
}finally {
sqlSession.commit();
sqlSession.close();
} if(flag == 1) {
System.out.println("删除成功!");
}
}
}

2、测试结果

(1)根据 id查询部门信息

(2)根据员工姓名模糊查询员工信息

(3)添加员工信息

(4)更新员工信息

(5)根据id删除员工信息

-

Mybatis笔记 - Mapper动态代理的更多相关文章

  1. MyBatis笔记——Mapper动态代理

    前提概要 Mapper接口开发方法只需要程序员编写Mapper接口(相当于Dao接口),由Mybatis框架根据接口定义创建接口的动态代理对象,代理对象的方法体同上边Dao接口实现类方法. Mappe ...

  2. JavaWeb_(Mybatis框架)Mapper动态代理开发_三

    系列博文: JavaWeb_(Mybatis框架)JDBC操作数据库和Mybatis框架操作数据库区别_一 传送门 JavaWeb_(Mybatis框架)使用Mybatis对表进行增.删.改.查操作_ ...

  3. 【Mybatis】-- Mapper动态代理开发注意事项

    1.1. Mapper动态代理方式 1.1.1. 开发规范 Mapper接口开发方法只需要程序员编写Mapper接口(相当于Dao接口),由Mybatis框架根据接口定义创建接口的动态代理对象,代理对 ...

  4. Mybatis之Mapper动态代理

    一.什么是Mapper的动态代理 采用Mapper动态代理方法只需要编写相应的Mapper接口(相当于Dao接口),那么Mybatis框架根据接口定义创建接口的动态代理对象,代理对象的方法体同Dao接 ...

  5. MyBatis使用Mapper动态代理开发Dao层

    开发规范 Mapper接口开发方法只需要程序员编写Mapper接口(相当于Dao接口),由Mybatis框架根据接口定义创建接口的动态代理对象,代理对象的方法体同原始Dao接口实现类方法. Mappe ...

  6. Mybatis(五)Spring整合Mybatis之mapper动态代理开发

    要操作的数据库: IDEA创建的Java工程,目录结构如下: 一.导包 1.spring的jar包 2.Mybatis的jar包 3.Spring+mybatis的整合包. 4.Mysql的数据库驱动 ...

  7. MyBatis通过Mapper动态代理来实现curd操作

    MyBatis官方推荐使用mapper代理方法开发mapper接口,程序员不需要编写mapper实现类,使用mapper代理方法时,输入参数可以使用pojo包装对象或者map对象,保证dao的通用性 ...

  8. MyBatis使用mapper动态代理实现DAO接口

    工具: mysql 5.5.62   IDEA 参考自:https://www.cnblogs.com/best/p/5688040.html 遇到的问题: 无法读取src/main/java下配置文 ...

  9. Mybatis之旅第二篇-Mapper动态代理方式

    一.引言 通过上一篇mybatis的入门学习,我们已经会使用mybatis实现简单的增删改查,但是我们也发现了用原始Dao开发的一些问题: Dao方法体存在重复代码:通过SqlSessionFacto ...

随机推荐

  1. 【Flutter学习】基本组件之基本表单组件

    一,概述 表单时一个包含表单元素的区域. 表单元素允许用户输入内容,比如文本域,下拉列表,单选框,复选框等.常见的应用场景有:登录,注册,输入信息等. 表单里有两个重要的组件: Form:用来做整个表 ...

  2. BZOJ 4698: Sdoi2008 Sandy的卡片(后缀数组+差分+二分答案)

    传送门 解题思路 看到一个子串加一个数字到另一个子串,自然可以想到差分.然后要把所有串都拼起来,求出\(height\)数组后可以二分答案来做,每次二分一个答案后统计一下连续的\(height> ...

  3. Apache解析漏洞复现(CVE-2017-15715),可以绕过黑名单

    照着P神的文章准备复现一下(总结一下经验) 环境的安装 这里面直接使用的vulhub里面的环境来进行安装的(为了方便吗) 基础环境如下    实际上Apache版本在2.4.0~2.4.29即可 i ...

  4. vue中的toast组件

    首先在components新建组件文件夹 随后在toast.vue中写入弹框样式 <template> <transition name="demo"> & ...

  5. Java-Class-@I:io.swagger.annotation.ApiParam

    ylbtech-Java-Class-@I:io.swagger.annotation.ApiParam 1.返回顶部   2.返回顶部 1. package com.ylbtech.api.cont ...

  6. CentOS6 图形界面(gnome)安装

    CentOS6相对于CentOS5的安装有了不少的进步,有不少默认的选项可以选择,如: Desktop :基本的桌面系统,包括常用的桌面软件,如文档查看工具. Minimal Desktop :基本的 ...

  7. HDU 6667 Roundgod and Milk Tea (思维)

    2019 杭电多校 8 1011 题目链接:HDU 6667 比赛链接:2019 Multi-University Training Contest 8 Problem Description Rou ...

  8. JAVA 字符串索引

    String类的substring()方法   截取字符串,在java语言中的用法 1.  public String substring(int beginIndex) 返回一个新字符串,它是此字符 ...

  9. 前端(二)—— CSS的引入方式、长度与颜色单位、常用样式、选择器

    CSS的引入方式.长度与颜色单位.常用样式.选择器 一.CSS的三种引入方式 1.行间式 <!doctype html> <html> <head> <met ...

  10. python中字符串输出格式

    print输入格式总结 通过使用ljust(),center(),rjust()函数来实现输入字符串的左右对齐,居中,右对齐等操作; 方法一:(函数不带参数,则默认以空格填充,注意:文字与空格总字符数 ...