由于上节 《mybatis 入门优化》中的dao实现类耦合了user.xml中的statment的id,例如:src.main.resource.userMapper.findUserByName。

这节采用mapper接口的方式实现dao。

IWebUserDao.java

package com.mozi.dao;

import java.util.List;
import com.mozi.entity.*; public interface IWebUserDao {
/**根据用户名称模糊查询用户信息*/
public List<WebUser> findUserByName(String username); /** 添加用户*/
public void insertUser(WebUser user); /** 根据ID删除用户*/
public void deleteUser(String id); /** 根据ID更新用户*/
public void updateUser(WebUser user);
}

sqlmap\userMapper.xml,

注意:

1、mapper配置中的namespace必须与接口去路径一致如:com.mozi.dao.IWebUserDao。

2、mapper的statment的id跟接口中的方法名一致,参数类型一致。

<?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">
<!-- namespace命名空间,作用就是对sql进行分类化的管理,理解为sql隔离
注意:使用mapper代理开发时,namespace有特殊作用
-->
<mapper namespace="com.mozi.dao.IWebUserDao">
<resultMap id="BaseResultMap" type="com.mozi.entity.WebUser" >
<id column="Name" property="name" jdbcType="VARCHAR" />
<result column="TrueName" property="trueName" jdbcType="VARCHAR" />
<result column="Pass" property="pass" jdbcType="VARCHAR" />
</resultMap>
<sql id="Base_Column_List" >
Name, TrueName, Pass
</sql> <select id="findUserById" parameterType="int" resultType="com.mozi.entity.WebUser" >
select * from WebUsers where id=#{id}
</select> <select id="findUserByName" parameterType="java.lang.String" resultType="com.mozi.entity.WebUser" >
select * from WebUsers where Name LIKE '%${value}%'
</select> <select id="findUserByName2" parameterType="java.lang.String" resultMap ="BaseResultMap" >
select * from WebUsers where Name LIKE '%${value}%'
</select> <!-- 添加用户 -->
<insert id="insertUser" parameterType="com.mozi.entity.WebUser" >
<!--
使用mysql的uuid(),实现非自增主键的返回。
执行过程:通过uuid()得到主键,将主键设置到user对象的Id的属性中,其次,在insert执行时,从user对象中取出Id属性值;
-->
insert into WebUsers (Name,TrueName,Pass) values(#{name},#{trueName},#{pass})
</insert> <!-- 删除用户 --> <delete id="deleteUser" parameterType="java.lang.String">
delete from WebUsers where Name=#{name}
</delete>
<!-- 更新用户 -->
<update id="updateUser" parameterType="com.mozi.entity.WebUser">
update WebUsers set Name=#{name},TrueName=#{trueName},Pass=#{pass}
where Name=#{name}
</update>
</mapper>

WebUserDaoMybatis3.java

package com.mozi.dao.impl;

import java.util.List;

import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory; import com.mozi.dao.IWebUserDao;
import com.mozi.entity.WebUser; public class WebUserDaoMybatis3 implements IWebUserDao {
private SqlSessionFactory sqlSessionFactory;
// 需要向dao实现类中注入SqlSessionFactory
// 通过构造方法注入
public WebUserDaoMybatis3(SqlSessionFactory sqlSessionFactory) {
this.sqlSessionFactory = sqlSessionFactory;
} @Override
public List<WebUser> findUserByName(String username) {
SqlSession sqlSession = sqlSessionFactory.openSession(); // 创建Usermapper对象,mybatis自动生成mapper代理对象
IWebUserDao mapper = sqlSession.getMapper(IWebUserDao.class);
List<WebUser> list = mapper.findUserByName(username);
sqlSession.close(); return list;
} @Override
public void insertUser(WebUser user) {
SqlSession sqlSession = sqlSessionFactory.openSession();
IWebUserDao mapper = sqlSession.getMapper(IWebUserDao.class);
// 执行插入操作
mapper.insertUser(user);
// 提交事务
sqlSession.commit();
// 释放资源
sqlSession.close();
} @Override
public void deleteUser(String id) {
SqlSession sqlSession = sqlSessionFactory.openSession();
IWebUserDao mapper = sqlSession.getMapper(IWebUserDao.class);
// 执行插入操作
mapper.deleteUser(id);
// 提交事务
sqlSession.commit();
// 释放资源
sqlSession.close();
} @Override
public void updateUser(WebUser user) {
SqlSession sqlSession = sqlSessionFactory.openSession();
IWebUserDao mapper = sqlSession.getMapper(IWebUserDao.class);
// 执行插入操作
mapper.updateUser(user);
// 提交事务
sqlSession.commit();
// 释放资源
sqlSession.close();
} }

测试类WebUserDaoImplTest.java

package com.mozi.test.java;

import static org.junit.Assert.*;

import java.io.IOException;
import java.io.InputStream;
import java.util.List; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test; import com.mozi.dao.IWebUserDao;
import com.mozi.dao.impl.WebUserDaoJdbc;
import com.mozi.dao.impl.WebUserDaoMybatis;
import com.mozi.dao.impl.WebUserDaoMybatis2;
import com.mozi.dao.impl.WebUserDaoMybatis3;
import com.mozi.entity.WebUser; public class WebUserDaoImplTest { private static SqlSessionFactory sqlSessionFactory = null; private static IWebUserDao dao = null; static{
String resource = "SqlMapConfig.xml";
InputStream inputStream = null;
try {
inputStream = Resources.getResourceAsStream(resource);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
dao = new WebUserDaoMybatis3(sqlSessionFactory);
} @Test
public void findUserByName() {
List<WebUser> userList = dao.findUserByName("aa");
System.out.println(userList);
assertNotNull(userList);
} @Test
public void insertUser() {
WebUser user = new WebUser();
user.setName("5");
user.setTrueName("lisi");
user.setPass("5");
dao.insertUser(user);
} @Test
public void deleteUser() {
dao.deleteUser("5");
} @Test
public void updateUser() {
WebUser user = new WebUser();
user.setName("5");
user.setTrueName("lisi");
user.setPass("666"); dao.updateUser(user);
}
}
 

mybatis 入门进阶之 mapper的更多相关文章

  1. MyBatis入门程序之Mapper代理方式

    Mapper代理的开发方式,程序员只需要编写mapper接口(相当于dao接口)即可,MyBatis会自动为mapper接口生成动态代理实现类. 一.开发规范 1.mapper接口的全限定名要和map ...

  2. mybatis 入门进阶之 pojo

    有时候我们dao方法声明的入参需要是自定义的pojo,以满足复杂的查询条件. IWebUserCustomDao.java package com.mozi.dao; import java.util ...

  3. mybatis入门篇:Mapper接口/关联查询/新增数据

    1.数据准备 2.编写实体类 package com.forest.owl.entity; import java.util.Date; public class User { private Lon ...

  4. MyBatis入门程序之mapper映射文件常用配置命令

    1.ResultMap高级结果映射 如果查询出的列名和属性名不一致,可以通过ResultMap做映射,放在statement的输出类型中 如下: 2.动态SQL,使用各种动态标签实现动态拼接sql,常 ...

  5. mybatis入门基础(二)----原始dao的开发和mapper代理开发

    承接上一篇 mybatis入门基础(一) 看过上一篇的朋友,肯定可以看出,里面的MybatisService中存在大量的重复代码,看起来不是很清楚,但第一次那样写,是为了解mybatis的执行步骤,先 ...

  6. Spring Boot入门系列(十七)整合Mybatis,创建自定义mapper 实现多表关联查询!

    之前讲了Springboot整合Mybatis,介绍了如何自动生成pojo实体类.mapper类和对应的mapper.xml 文件,并实现最基本的增删改查功能.mybatis 插件自动生成的mappe ...

  7. MyBatis1:MyBatis入门

    MyBatis是什么 MyBatis是什么,MyBatis的jar包中有它的官方文档,文档是这么描述MyBatis的: MyBatis is a first class persistence fra ...

  8. MyBatis入门基础(一)

    一:对原生态JDBC问题的总结 新项目要使用mybatis作为持久层框架,由于本人之前一直使用的Hibernate,对mybatis的用法实在欠缺,最近几天计划把mybatis学习一哈,特将学习笔记记 ...

  9. MyBatis入门案例、增删改查

    一.MyBatis入门案例: ①:引入jar包 ②:创建实体类 Dept,并进行封装 ③ 在Src下创建大配置mybatis-config.xml <?xml version="1.0 ...

随机推荐

  1. ichartjs 使用BUG,assign_scale:true 解决

    今天纯属灌水,好久没灌水的. 最近使用了flotr2 和 ichartjs进行canvas图标的开发,都不能满足需求. 没办法,先将就用用吧.然后,既然其他大神推荐使用ichartjs,为了统一,我也 ...

  2. C++中出现的计算机术语4

    adaptor(适配器) 一种标准库类型.函数或迭代器,使某种标准库类型.函数或迭代器的行为类似于第二种标准库类型.函数或迭代器.系统提供了三种顺序容器适配器:stack(栈).queue(队列)以及 ...

  3. [译]Java 设计模式之中介者

    (文章翻译自Java Design Pattern: Mediator) 中介者设计模式被用于一组的同事进行协作.这些同事不彼此进行直接的交流联系,但是是通过中介者. 在下面的例子中,A同事想去说话, ...

  4. ReSharper 8.1支持Visual Studio 2013的特色——超强滚动条

    自ReSharper 8.1发布以来,便支持Visual Studio 2013.其中peek功能是它的亮点,滚动条则是它的特色. 接下来小编将展示ReSharper在Visual Studio 20 ...

  5. Your build host version of Xamarin.IOS (release NO.)is too recent to work with the IOS designer

    Encounted such error in VS after I update the xamarin at Mac side.Here is the solution for u to refe ...

  6. 制作iis自动安装包

    原文:制作iis自动安装包 MS 一直没有提供可独立安装的 IIS 安装包,Windows 的缺省安装没有安装它,通常要到控制面板的"添加/删除 Windows 程序"中去选择安装 ...

  7. How do I create an IIS application and application pool using InnoSetup script

    Create an IIS application. Create a new IIS application pool and set it's .NET version to 4. Set the ...

  8. AngularJs ng-repeat

    AngularJs ng-repeat 必须注意的性能问题 AngularJs 的 ng-repeat 让我们非常方便的遍历数组生成 Dom 元素,但是使用不当也会有性能问题. 在项目中我们使用 ng ...

  9. Oracle索引——位图索引

    1.语法create bitmap index index_name on 表名(字段);2.举个例子你就能明白了:如有表 test(id,name,address)数据(1,张三,大连)(2,李四, ...

  10. select省市联动选择城市 asp.net mvc4

    本文在 http://www.cnblogs.com/darrenji/p/3606703.html(感谢博主的分享)基础上加入全国各省市,从文件中读取全国省市县,组成省市联动的选择标签 在Model ...